生成全RGB空间画布颜色选择器(Generating a canvas color picker w

2019-10-19 05:00发布

由于RGB需要立方体显示所有颜色有更多的方式来显示所有的颜色。 我想有在全彩色显示在彩虹的所有颜色的圆圈 - 并单击显示所有在它自己的小2D空间选择的颜色不同亮度时。

我想生成的东西,看起来这样的形象使用帆布:

我对这样的尝试:

使用Javascript:

function ColorPicker(element) {
    this.element = element;

    this.init = function() {
        var diameter = this.element.offsetWidth;

        var canvas = document.createElement('canvas');
        canvas.height = diameter;
        canvas.width = diameter,
        this.canvas = canvas;

        this.renderColorMap();

        element.appendChild(canvas);

        this.setupBindings();
    };

    this.renderColorMap = function() {
        var canvas = this.canvas;
        var ctx = canvas.getContext('2d');

        var radius = canvas.width / 2;
        var toRad = (2 * Math.PI) / 360;
        var step = 1 / radius;

        ctx.clearRect(0, 0, canvas.width, canvas.height);

        for(var i = 0; i < 360; i += step) {
            var rad = i * toRad;
            ctx.strokeStyle = 'hsl(' + i + ', 100%, 50%)';
            ctx.beginPath();
            ctx.moveTo(radius, radius);
            ctx.lineTo(radius + radius * Math.cos(rad), radius + radius * Math.sin(rad));
            ctx.stroke();
        }

        ctx.fillStyle = 'rgb(255, 255, 255)';
        ctx.beginPath();
        ctx.arc(radius, radius, radius * 0.8, 0, Math.PI * 2, true);
        ctx.closePath();
        ctx.fill();

        // render the rainbow box here ----------
    };

    this.renderMouseCircle = function(x, y) {
        var canvas = this.canvas;
        var ctx = canvas.getContext('2d');

        ctx.strokeStyle = 'rgb(255, 255, 255)';
        ctx.lineWidth = '2';
        ctx.beginPath();
        ctx.arc(x, y, 10, 0, Math.PI * 2, true);
        ctx.closePath();
        ctx.stroke();
    };

    this.setupBindings = function() {
        var canvas = this.canvas;
        var ctx = canvas.getContext('2d');
        var self = this;

        canvas.addEventListener('click', function(e) {
            var x = e.offsetX || e.clientX - this.offsetLeft;
            var y = e.offsetY || e.clientY - this.offsetTop;

            var imgData = ctx.getImageData(x, y, 1, 1).data;
            var selectedColor = new Color(imgData[0], imgData[1], imgData[2]);
            // generate this square here.

            self.renderMouseCircle(x, y);
        }, false);
    };

    this.init();
}

new ColorPicker(document.querySelector('.color-space'));

的jsfiddle: http://jsfiddle.net/yH6JE/

我有一个很难搞清楚如何生成中间这个广场。 基本上我想在最左边中间的颜色是一样的环上的一个 - 我已经通过点击选择。

我怎样才能产生这种类型的梯度方的?

Answer 1:

它看起来像你想HSL色彩矩形,与色轮被选中的色调。

这里是一个函数我放在一起绘制矩形:

function draw(canvas, hue){
    var ctx = canvas.getContext('2d');
    for(row=0; row<100; row++){
        var grad = ctx.createLinearGradient(0, 0, 100,0);
        grad.addColorStop(0, 'hsl('+hue+', 100%, '+(100-row)+'%)');
        grad.addColorStop(1, 'hsl('+hue+', 0%, '+(100-row)+'%)');
        ctx.fillStyle=grad;
        ctx.fillRect(0, row, 100, 1);
    }   
}

希望这你想要做什么。 例如这里: 彩色矩形JS提琴



Answer 2:

如果你愿意,你也可以使用一个圆。 我认为这是比较容易选择颜色的方式。

我做了这个: https://github.com/JeroenvO/html5-colorpicker

也许你可以使用它作为指南。 我只用图片与一些不透明性和在JavaScript中没有梯度计算。



文章来源: Generating a canvas color picker with full rgb space