所有
我在RGB色彩空间中绘制了一些颜色的三维图。目前这些商标都是相同的颜色。我希望每个标记都是它在空间中所代表的颜色。因此,情节红色边角的标记应为红色等等......
我到目前为止的代码如下。
感谢您的帮助,
- 比尔
// RGB color data for a few shades of pink and red
r = [1, 1, 1, 1, 0.8588235294117647, 0.7803921568627451, 1, 0.9803921568627451, 0.9137254901960784, 0.9411764705882353]';
g = [0.7529411764705882, 0.7137254901960785, 0.4117647058823529, 0.07843137254901961, 0.4392156862745098, 0.08235294117647059, 0.6274509803921569, 0.5019607843137255, 0.5882352941176471, 0.5019607843137255]';
b = [0.796078431372549, 0.7568627450980392, 0.7058823529411765, 0.5764705882352941, 0.5764705882352941, 0.5215686274509804, 0.4784313725490196, 0.4470588235294118, 0.4784313725490196, 0.5019607843137255]';
// Draw 3D graph from R G B vectors
param3d(r,g,b,35,45,"Red@Green@Blue",[2,4]);
title("Some Shades of Pink and Red");
// Set marks to ball style
p=get("hdl");
p.mark_style = 9;
// Turn lines off so we just have points
e = gce();
e.line_mode="off";
e.mark_mode="on";
// Set color map to our RGB values
cmap=[r g b];
// Put some code here to color each mark with its respective color
// I have no idea what to do at this point.
答案 0 :(得分:0)
据我所知,您只能将折线中所有标记的mark_foreground颜色设置为相同的颜色。 the documentation.
也证实了这一点快速解决方案是为每个标记创建折线并为其着色。一个更好的解决方案将实现表面图。
我根据你的代码创建了一个工作示例,它不漂亮并且有很大的改进空间。但它解决了你的直接问题。
// RGB color data for a few shades of pink and red
r = [1, 1, 1, 1, 0.8588235294117647, 0.7803921568627451, 1, 0.9803921568627451, 0.9137254901960784, 0.9411764705882353]';
g = [0.7529411764705882, 0.7137254901960785, 0.4117647058823529, 0.07843137254901961, 0.4392156862745098, 0.08235294117647059, 0.6274509803921569, 0.5019607843137255, 0.5882352941176471, 0.5019607843137255]';
b = [0.796078431372549, 0.7568627450980392, 0.7058823529411765, 0.5764705882352941, 0.5764705882352941, 0.5215686274509804, 0.4784313725490196, 0.4470588235294118, 0.4784313725490196, 0.5019607843137255]';
// Draw 3D graph from R G B vectors
for i=1:length(r)
param3d( r(i), g(i), b(i), 35,45,"Red@Green@Blue",[2,4]);
if( i == 1 )
title("Some Shades of Pink and Red");
// Set color map to our RGB values
cmap=[r g b];
// Put some code here to color each mark with its respective color
//assign the colormap to the current figure
f=gcf();
f.color_map=cmap;
end
p=get("hdl");
p.mark_style = 9;
// Turn lines off so we just have points
e = gce();
e.line_mode="off";
e.mark_mode="on";
// Assign the mark color
e.mark_foreground= i ;
end