Support Firefox 3.6 still, with surprising little effort.

Why, I don't really know :)
This commit is contained in:
Jürg Lehni 2014-03-18 12:38:29 +01:00
parent 62f7b0d73e
commit d28bac0734
5 changed files with 42 additions and 10 deletions

View file

@ -32,7 +32,7 @@ fi
./preprocess.sh $MODE ../src/paper.js "-i '../src/constants.js'" ../dist/paper-full.js ./preprocess.sh $MODE ../src/paper.js "-i '../src/constants.js'" ../dist/paper-full.js
./preprocess.sh $MODE ../src/paper.js "-o '{ \"paperScript\": false, \"palette\": false }' -i '../src/constants.js'" ../dist/paper-core.js ./preprocess.sh $MODE ../src/paper.js "-o '{ \"paperScript\": false, \"palette\": false }' -i '../src/constants.js'" ../dist/paper-core.js
./preprocess.sh $MODE ../src/paper.js "-o '{ \"environment\": \"node\" }' -i '../src/constants.js'" ../dist/paper-node.js ./preprocess.sh $MODE ../src/paper.js "-o '{ \"environment\": \"node\", \"legacy\": false }' -i '../src/constants.js'" ../dist/paper-node.js
# Remove the existing file and copy paper-full.js to paper.js now # Remove the existing file and copy paper-full.js to paper.js now
if [ -f ../dist/paper.js ] if [ -f ../dist/paper.js ]

View file

@ -232,20 +232,24 @@ var BlendMode = new function() {
Base.each(modes, function(func, mode) { Base.each(modes, function(func, mode) {
// Blend #330000 (51) and #aa0000 (170): // Blend #330000 (51) and #aa0000 (170):
// Multiplying should lead to #220000 (34) // Multiplying should lead to #220000 (34)
ctx.save();
// For darken we need to reverse color parameters in order to test mode. // For darken we need to reverse color parameters in order to test mode.
var darken = mode === 'darken', var darken = mode === 'darken',
ok = false; ok = false;
ctx.save();
// FF 3.6 throws exception when setting globalCompositeOperation to
// unsupported values.
try {
ctx.fillStyle = darken ? '#300' : '#a00'; ctx.fillStyle = darken ? '#300' : '#a00';
ctx.fillRect(0, 0, 1, 1); ctx.fillRect(0, 0, 1, 1);
ctx.globalCompositeOperation = mode; ctx.globalCompositeOperation = mode;
if (ctx.globalCompositeOperation === mode) { if (ctx.globalCompositeOperation === mode) {
ctx.fillStyle = darken ? '#a00' : '#300'; ctx.fillStyle = darken ? '#a00' : '#300';
ctx.fillRect(0, 0, 1, 1); ctx.fillRect(0, 0, 1, 1);
ok = ctx.getImageData(0, 0, 1, 1).data[0] !== (darken ? 170 : 51); ok = ctx.getImageData(0, 0, 1, 1).data[0] !== darken ? 170 : 51;
} }
nativeModes[mode] = ok; } catch (e) {}
ctx.restore(); ctx.restore();
nativeModes[mode] = ok;
}); });
CanvasProvider.release(ctx); CanvasProvider.release(ctx);

23
src/legacy.js Normal file
View file

@ -0,0 +1,23 @@
/*
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
* http://paperjs.org/
*
* Copyright (c) 2011 - 2014, Juerg Lehni & Jonathan Puckey
* http://scratchdisk.com/ & http://jonathanpuckey.com/
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
// Support for legacy browsers (mainly FF 3.6). Remove 2nd half of 2014?
if (!Array.isArray) {
Array.isArray = function(obj) {
return Object.prototype.toString.call(obj) === '[object Array]';
};
}
if (!document.head) {
document.head = document.getElementsByTagName('head')[0];
}

View file

@ -18,6 +18,7 @@ var __options = {
parser: 'acorn', parser: 'acorn',
version: 'dev', version: 'dev',
environment: 'browser', environment: 'browser',
legacy: true,
stats: true, stats: true,
svg: true, svg: true,
fatlineClipping: true, fatlineClipping: true,

View file

@ -40,6 +40,10 @@ var paper = new function(undefined) {
/*#*/ include('../bower_components/stats.js/build/stats.min.js'); /*#*/ include('../bower_components/stats.js/build/stats.min.js');
/*#*/ } // __options.stats /*#*/ } // __options.stats
/*#*/ if (__options.legacy) {
/*#*/ include('legacy.js');
/*#*/ } // __options.legacy
/*#*/ if (__options.version == 'dev') { /*#*/ if (__options.version == 'dev') {
/*#*/ include('constants.js'); /*#*/ include('constants.js');
/*#*/ } // __options.version == 'dev' /*#*/ } // __options.version == 'dev'