SciLab: цветовой график RGB, пытающийся закрасить каждую метку соответствующим цветом

Все,

Я сделал 3D-график некоторых цветов в цветовом пространстве 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.

1 ответ

Насколько я знаю, вы можете установить только цвет mark_foreground всех меток на полилинии на один и тот же цвет. Это также подтверждается документацией.

Быстрое решение - создать ломаную линию для каждого маркера и раскрасить ее. Более приятное решение - реализовать поверхностный сюжет.

Рабочий пример

Я создал рабочий пример, основанный на вашем коде, он не очень хорош и имеет много возможностей для улучшения. Но это решает ваш прямой вопрос.

// 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
Другие вопросы по тегам