這其實很簡單,只需擴展文本對象這樣
<script>
(function() {
function GradientText(text, font, color) {
this.Text_constructor(text, font, color);
}
var p = createjs.extend(GradientText, createjs.Text);
p._drawTextLine = function (ctx, text, y) {
if (this.gradient) {
var height = this.getMeasuredLineHeight();
var my_gradient = ctx.createLinearGradient(0, y, 0, y + height);
my_gradient.addColorStop(0, "black");
my_gradient.addColorStop(1, "white");
ctx.fillStyle = my_gradient;
ctx.fillText(text, 0, y, this.maxWidth || 0xFFFF);
} else {
this.Text__drawTextLine(ctx, text, y);
}
};
window.GradientText = createjs.promote(GradientText, "Text");
}());
</script>
現在只需創建一個這樣的GradientText
一個實例:
var text = new GradientText("Hello world!", "20px Arial", "#ff0000");
text.gradient = true;
你應該看到一個梯度文本時加它到了stage
。這裏是它的jsfiddle:https://jsfiddle.net/r94zmwxa/
P.S.我剛剛寫了一個例子(黑白),但您可以從this.gradient
更改addColorStop
以動態設置漸變顏色!
這些功能有什麼改變嗎? – bks
不,這絕對有可能,請參閱下面的答案。 – supersan