Почему это не работает в Firefox? - PullRequest
0 голосов
/ 14 октября 2011

Вот пример .

HTML

<body>
    <p>Click on a color to begin!</p>
<canvas id="colorPicker" width="300" height="300"></canvas>
</body>

JavaScript

var elem = document.getElementById('colorPicker');
var context = elem.getContext('2d');
var color, hue = [[255,   0,   0 ],[255, 255,   0 ],[  0, 255,   0 ],[  0, 255, 255 ],[  0,   0, 255 ],[255,   0, 255 ],[255,   0,   0],]
gradient = context.createLinearGradient(0, 0, elem.width, 0);
for (var i = 0; i <= 6; i++) {
    color = 'rgb(' + hue[i][0] + ', ' + hue[i][1] + ', ' + hue[i][2] + ')';
    gradient.addColorStop(i * 1/6, color);
    }
gradient2 = context.createLinearGradient(0, 0, 0, elem.height);
gradient2.addColorStop(0, 'rgba(255, 255, 255, 1)');
gradient2.addColorStop(0.01, 'rgba(255, 255, 255, 1)');
gradient2.addColorStop(0.50, 'rgba(255, 255, 255, 0)');
gradient2.addColorStop(0.52, 'rgba(255, 255, 255, 0)');
gradient2.addColorStop(0.75, 'rgba(0, 0, 0, 1)');
gradient2.addColorStop(1, 'rgba(255, 255, 255, 1)');
context.fillStyle = gradient;
context.fillRect(0, 0, 500, 500);
context.fillStyle = gradient2;
context.fillRect(0, 0, 500, 500);

elem.addEventListener('click', function(e) {
    var x = e.offsetX; // lame but close enough for now
    var y = e.offsetY;
    var data = context.getImageData(x, y, 1, 1).data;
    // just paint it to the bottom right as an example for now:
    var rgb = 'rgb(' + data[0] + ',' + data[1] + ',' + data[2] + ')';
    $('#fluidWrap').css({backgroundColor: rgb});
    $('body').css({backgroundColor: rgb});
    $('.content').css({backgroundColor: rgb});
}, false);

Работает в любом браузере, кроме Firefox.Это как-то связано с тем, что это RGB?Я посмотрел, и это нормально использовать RGB в background-color.

Что я могу сделать, чтобы сделать эту работу?

Ответы [ 2 ]

3 голосов
/ 14 октября 2011

Если вы попытаетесь использовать Firebug и точку останова на eventHandler, вы увидите, что в Firefox событие click имеет:

e.clientX
e.clientY

но не e.offset.

Изменено и работает для Firefox.

0 голосов
/ 14 октября 2011

Это не работает в IE8 (для меня)

Исправлено здесь http://jsfiddle.net/jdb1991/XR3QF/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...