2013-04-01 4 views
12

Я пытаюсь изменить цвет для каждой строки моих сообщений на холсте, но пока ничего не добился. Я попытался создать переменную для каждого из них, но все равно не повезло. любая помощь будет оценена по достоинству.Изменение цвета для fillText() на HTML5 <canvas>

function initiate(){ 
    var elem = document.getElementById("canvas"); 
    canvas = elem.getContext("2d"); 
    addEventListener("mousemove", animation); 

    canvas.shadowColor = "rgba(0, 0, 0, 0.5)"; 
    canvas.shadowOffsetX = 4; 
    canvas.shadowOffsetY = 4; 
    canvas.shadowBlur = 5; 

    canvas.font = "bold 24px verdana, sans-serif "; 
    var welcomeMessage ="Welcome to the store!"; 
    canvas.textAlign = "start"; 
    canvas.textBaseline = "bottom"; 
    canvas.fillText(welcomeMessage, 400, 50); 

    canvas.font = "bold 14px verdana, sans-serif"; 
    var message2 = "Your favorite store for videos games and latest DVDs!"; 
    canvas.textAlign = "start"; 
    canvas.textBaseline = "bottom"; 
    canvas.fillText(message2, 400, 100); 

    canvas.font = "bold 12px verdana, sans-serif"; 
    canvas.textAlign = "start"; 
    canvas.textBaseline = "bottom"; 
    // Create gradient 
    //var gradient=canvas.createLinearGradient(0,0,c.width,0); 
    //gradient.addColorStop("0","magenta"); 
    //gradient.addColorStop("0.5","blue"); 
    //gradient.addColorStop("1.0","red"); 
    //canvas.fillStyle = gradient; 
    canvas.fillText(" <-- Move your mouse aroud to interact with Macroplay smily!", 400, 250); 


} 

ответ

22

Вы должны установить цвет текста.

Что-то вроде этого:

canvas.font = "bold 24px verdana, sans-serif "; 
var welcomeMessage ="Welcome to the store!"; 
canvas.textAlign = "start"; 
canvas.textBaseline = "bottom"; 
canvas.fillStyle = "#ff0000"; //<======= here 
canvas.fillText(welcomeMessage, 400, 50); 

canvas.font = "bold 14px verdana, sans-serif"; 
var message2 = "Your favorite store for videos games and latest DVDs!"; 
canvas.textAlign = "start"; 
canvas.textBaseline = "bottom"; 
canvas.fillStyle = "#00ff00"; //<======= and here 
canvas.fillText(message2, 400, 100); 

Кроме того, это может быть хорошей идеей, чтобы назвать вашу контекстную переменную «контекста» или «CXT» вместо «холст». Было бы менее запутанным :)

+0

Спасибо! Это сработало! :) – user2193106

+1

Добро пожаловать :). Если это хороший ответ, можете ли вы проголосовать за него и отметить его как правильный ответ? Спасибо. –

+0

@ Gwennael Я сделал upvote ... !!! –

2

Вы пробовали простые fillStyles, как:

canvas.fillStyle = "#ff00ff"; 

Текст рендеринга на <canvas> не поддерживает расширенные стили заливки.

Просто установите новый fillStyle перед визуализацией каждого сообщения.

+0

Спасибо, это сработало! :) – user2193106

Смежные вопросы