Fix linear gradient rendering

This commit is contained in:
Niklas von Hertzen 2014-05-18 19:14:22 +03:00
parent d6ed6c0194
commit 6959058560
5 changed files with 91 additions and 15 deletions

View File

@ -285,7 +285,7 @@ function ImageLoader(options, support) {
this.link = null; this.link = null;
this.options = options; this.options = options;
this.support = support; this.support = support;
this.origin = window.location.protocol + window.location.hostname; this.origin = window.location.protocol + window.location.hostname + window.location.port;
} }
ImageLoader.prototype.findImages = function(nodes) { ImageLoader.prototype.findImages = function(nodes) {
@ -330,6 +330,8 @@ ImageLoader.prototype.loadImage = function(imageData) {
return new LinearGradientContainer(imageData); return new LinearGradientContainer(imageData);
} else if (imageData.method === "gradient") { } else if (imageData.method === "gradient") {
return new WebkitGradientContainer(imageData); return new WebkitGradientContainer(imageData);
} else {
return new DummyImageContainer(imageData);
} }
}; };
@ -343,7 +345,7 @@ ImageLoader.prototype.isSameOrigin = function(url) {
var link = this.link || (this.link = document.createElement("a")); var link = this.link || (this.link = document.createElement("a"));
link.href = url; link.href = url;
link.href = link.href; // IE9, LOL! - http://jsfiddle.net/niklasvh/2e48b/ link.href = link.href; // IE9, LOL! - http://jsfiddle.net/niklasvh/2e48b/
var origin = link.protocol + link.hostname; var origin = link.protocol + link.hostname + link.port;
return (origin === this.origin); return (origin === this.origin);
}; };
@ -408,8 +410,33 @@ function LinearGradientContainer(imageData) {
} }
}, this); }, this);
imageData.args.slice(1).forEach(function(colorStop) { this.colorStops = imageData.args.slice(1).map(function(colorStop) {
// console.log(colorStop, colorStop.match(this.stepRegExp)); var colorStopMatch = colorStop.match(this.stepRegExp);
return {
color: colorStopMatch[1],
stop: colorStopMatch[3] === "%" ? colorStopMatch[2] / 100 : null
};
}, this);
if (this.colorStops[0].stop === null) {
this.colorStops[0].stop = 0;
}
if (this.colorStops[this.colorStops.length - 1].stop === null) {
this.colorStops[this.colorStops.length - 1].stop = 1;
}
this.colorStops.forEach(function(colorStop, index) {
if (colorStop.stop === null) {
this.colorStops.slice(index).some(function(find, count) {
if (find.stop !== null) {
colorStop.stop = ((find.stop - this.colorStops[index - 1].stop) / (count + 1)) + this.colorStops[index - 1].stop;
return true;
} else {
return false;
}
}, this);
}
}, this); }, this);
} }
@ -1707,8 +1734,15 @@ CanvasRenderer.prototype.renderBackgroundRepeat = function(imageContainer, backg
CanvasRenderer.prototype.renderBackgroundGradient = function(gradientImage, bounds) { CanvasRenderer.prototype.renderBackgroundGradient = function(gradientImage, bounds) {
if (gradientImage instanceof LinearGradientContainer) { if (gradientImage instanceof LinearGradientContainer) {
var gradient = this.ctx.createLinearGradient(bounds.left, bounds.top, bounds.right, bounds.bottom); var gradient = this.ctx.createLinearGradient(
//console.log(gradientImage, bounds, gradient); bounds.left + bounds.width * gradientImage.x0,
bounds.top + bounds.height * gradientImage.y0,
bounds.left + bounds.width * gradientImage.x1,
bounds.top + bounds.height * gradientImage.y1);
gradientImage.colorStops.forEach(function(colorStop) {
gradient.addColorStop(colorStop.stop, colorStop.color);
});
this.rectangle(bounds.left, bounds.top, bounds.width, bounds.height, gradient);
} }
}; };

File diff suppressed because one or more lines are too long

View File

@ -23,8 +23,33 @@ function LinearGradientContainer(imageData) {
} }
}, this); }, this);
imageData.args.slice(1).forEach(function(colorStop) { this.colorStops = imageData.args.slice(1).map(function(colorStop) {
// console.log(colorStop, colorStop.match(this.stepRegExp)); var colorStopMatch = colorStop.match(this.stepRegExp);
return {
color: colorStopMatch[1],
stop: colorStopMatch[3] === "%" ? colorStopMatch[2] / 100 : null
};
}, this);
if (this.colorStops[0].stop === null) {
this.colorStops[0].stop = 0;
}
if (this.colorStops[this.colorStops.length - 1].stop === null) {
this.colorStops[this.colorStops.length - 1].stop = 1;
}
this.colorStops.forEach(function(colorStop, index) {
if (colorStop.stop === null) {
this.colorStops.slice(index).some(function(find, count) {
if (find.stop !== null) {
colorStop.stop = ((find.stop - this.colorStops[index - 1].stop) / (count + 1)) + this.colorStops[index - 1].stop;
return true;
} else {
return false;
}
}, this);
}
}, this); }, this);
} }

View File

@ -104,8 +104,15 @@ CanvasRenderer.prototype.renderBackgroundRepeat = function(imageContainer, backg
CanvasRenderer.prototype.renderBackgroundGradient = function(gradientImage, bounds) { CanvasRenderer.prototype.renderBackgroundGradient = function(gradientImage, bounds) {
if (gradientImage instanceof LinearGradientContainer) { if (gradientImage instanceof LinearGradientContainer) {
var gradient = this.ctx.createLinearGradient(bounds.left, bounds.top, bounds.right, bounds.bottom); var gradient = this.ctx.createLinearGradient(
//console.log(gradientImage, bounds, gradient); bounds.left + bounds.width * gradientImage.x0,
bounds.top + bounds.height * gradientImage.y0,
bounds.left + bounds.width * gradientImage.x1,
bounds.top + bounds.height * gradientImage.y1);
gradientImage.colorStops.forEach(function(colorStop) {
gradient.addColorStop(colorStop.stop, colorStop.color);
});
this.rectangle(bounds.left, bounds.top, bounds.width, bounds.height, gradient);
} }
}; };

View File

@ -8,9 +8,6 @@
html { html {
background-color: red; background-color: red;
} }
body {
background-color: lime;
}
.small div{ .small div{
width:100px; width:100px;
height:100px; height:100px;
@ -90,6 +87,18 @@
background: linear-gradient(top, #f0b7a1 0%, #8c3310 50%, #752201 51%, #bf6e4e 100%); background: linear-gradient(top, #f0b7a1 0%, #8c3310 50%, #752201 51%, #bf6e4e 100%);
} }
.linearGradient6 {
/* FF 3.6+ */
background: -moz-linear-gradient(left, #cedbe9 0%, #aac5de 17%, #6199c7 50%, #3a84c3 51%, #419ad6, #26558b 100%);
/* Chrome 10+, Safari 5.1+ */
background: -webkit-linear-gradient(left, #cedbe9 0%, #aac5de 17%, #6199c7 50%, #3a84c3 51%, #419ad6, #26558b 100%);
/* Opera 11.10+ */
background: -o-linear-gradient(left, #cedbe9 0%, #aac5de 17%, #6199c7 50%, #3a84c3 51%, #419ad6, #26558b 100%);
/* IE10+ */
background: -ms-linear-gradient(left, #cedbe9 0%, #aac5de 17%, #6199c7 50%, #3a84c3 51%, #419ad6, #26558b 100%);
/* W3C */
background: linear-gradient(left, #cedbe9 0%, #aac5de 17%, #6199c7 50%, #3a84c3 51%, #419ad6, #26558b 100%);
}
</style> </style>
</head> </head>
@ -100,6 +109,7 @@
<div class="linearGradient3">&nbsp;</div> <div class="linearGradient3">&nbsp;</div>
<div class="linearGradient4">&nbsp;</div> <div class="linearGradient4">&nbsp;</div>
<div class="linearGradient5">&nbsp;</div> <div class="linearGradient5">&nbsp;</div>
<div class="linearGradient6">&nbsp;</div>
</div> </div>
</body> </body>
</html> </html>