Установите заливку фона, ход и непрозрачность холста HTML5.
Я использую приведенный ниже код для установки стилей myCanvas
, но я не могу установить fillStyle
. Тем не менее, strokeStyle
и lineWidth
работают нормально. Может ли кто-нибудь помочь в этом?
Init()
{
var can = byId('myCanvas');
// get it context
hdc = can.getContext('2d');
hdc.strokeStyle = 'red';
hdc.lineWidth = 2;
// Fill the path
hdc.fillStyle = "#9ea7b8";
hdc.opacity = 0.2;
hdc.fill();
}
// And call the drawPoly function with coordinates.
function drawPoly(coOrdStr) {
var canvas = byId('myCanvas');
hdc.clearRect(0, 0, canvas.width, canvas.height);
var mCoords = coOrdStr.split(',');
var i, n;
n = mCoords.length;
hdc.beginPath();
hdc.moveTo(mCoords[0], mCoords[1]);
for (i = 2; i < n; i += 2) {
hdc.lineTo(mCoords[i], mCoords[i + 1]);
}
hdc.lineTo(mCoords[0], mCoords[1]);
hdc.stroke();
}
Ответы
Ответ 1
Init()
{
var can = document.getElementById('myCanvas');
h = parseInt(document.getElementById("myCanvas").getAttribute("height"));
w=parseInt(document.getElementById("myCanvas").getAttribute("width"));
// get it context
hdc = can.getContext('2d');
hdc.strokeStyle = 'red';
hdc.lineWidth = 2;
// Fill the path
hdc.fillStyle = "#9ea7b8";
hdc.fillRect(0,0,w,h);
can.style.opacity = '0.2';
}
Будьте осторожны, чтобы style.height
или style.width
не работали с холстом.
Ответ 2
Стиль /CSS:
<style>#myCanvas { background-color: rgba(158, 167, 184, 0.2); }</style>
JQuery
$('#myCanvas').css('background-color', 'rgba(158, 167, 184, 0.2)');
JavaScript:
document.getElementById("myCanvas").style.backgroundColor = 'rgba(158, 167, 184, 0.2)';
Ответ 3
На самом деле, style.height
и style.width
работают с холстом, вы также можете установить их на другой размер без изменения внутреннего разрешения, например. запуск игры 400x300 в полноэкранном холсте 1024x768.