手机
当前位置:查字典教程网 >网页设计 >HTML5教程 >HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)
HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)
摘要:演示HTML5CanvasFill与Stroke文字效果,基于Canvas如何实现纹理填充与描边。一:颜色填充与描边颜色填充可以通过fill...

演示HTML5 Canvas Fill 与Stroke文字效果,基于Canvas如何实现纹理填充与描边。

一:颜色填充与描边

颜色填充可以通过fillStyle来实现,描边颜色可以通过strokeStyle来实现。简单示例

如下:

// fill and stroke text

ctx.font = '60pt Calibri';

ctx.lineWidth = 3;

ctx.strokeStyle = 'green';

ctx.strokeText('Hello World!', 20, 100);

ctx.fillStyle = 'red';

ctx.fillText('Hello World!', 20, 100);

二:纹理填充与描边

HTML5 Canvas还支持纹理填充,通过加载一张纹理图像,然后创建画笔模式,创建纹理模式的API为ctx.createPattern(imageTexture,"repeat");第二参数支持四个值,分别为”repeat-x”, ”repeat-y”, ”repeat”,”no-repeat”意思是纹理分别沿着X轴,Y轴,XY方向沿重复或者不重复。纹理描边与填充的代码如下:

var woodfill = ctx.createPattern(imageTexture,"repeat");

ctx.strokeStyle = woodfill;

ctx.strokeText('Hello World!', 20, 200);

// fill rectangle

ctx.fillStyle = woodfill;

ctx.fillRect(60, 240, 260, 440);

纹理图片:

HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)1

三:运行效果

1

代码:

<!DOCTYPE html>

<html>

<head>

<meta http-equiv="X-UA-Compatible" content="chrome=IE8">

<meta http-equiv="Content-type" content="text/html;charset=UTF-8">

<title>Canvas Fill And Stroke Text Demo</title>

<link href="default.css" rel="stylesheet" />

<script>

var ctx = null; // global variable 2d context

var imageTexture = null;

window.onload = function() {

var canvas = document.getElementById("text_canvas");

console.log(canvas.parentNode.clientWidth);

canvas.width = canvas.parentNode.clientWidth;

canvas.height = canvas.parentNode.clientHeight;

if (!canvas.getContext) {

console.log("Canvas not supported. Please install a HTML5 compatible browser.");

return;

}

// get 2D context of canvas and draw rectangel

ctx = canvas.getContext("2d");

ctx.fillStyle="black";

ctx.fillRect(0, 0, canvas.width, canvas.height);

// fill and stroke text

ctx.font = '60pt Calibri';

ctx.lineWidth = 3;

ctx.strokeStyle = 'green';

ctx.strokeText('Hello World!', 20, 100);

ctx.fillStyle = 'red';

ctx.fillText('Hello World!', 20, 100);

// fill and stroke by pattern

imageTexture = document.createElement('img');

imageTexture.src = "../pattern.png";

imageTexture.onload = loaded();

}

function loaded() {

// delay to image loaded

setTimeout(textureFill, 1000/30);

}

function textureFill() {

// var woodfill = ctx.createPattern(imageTexture, "repeat-x");

// var woodfill = ctx.createPattern(imageTexture, "repeat-y");

// var woodfill = ctx.createPattern(imageTexture, "no-repeat");

var woodfill = ctx.createPattern(imageTexture, "repeat");

ctx.strokeStyle = woodfill;

ctx.strokeText('Hello World!', 20, 200);

// fill rectangle

ctx.fillStyle = woodfill;

ctx.fillRect(60, 240, 260, 440);

}

</script>

</head>

<body>

<h1>HTML5 Canvas Text Demo - By Gloomy Fish</h1>

<pre>Fill And Stroke</pre>

<div id="my_painter">

<canvas id="text_canvas"></canvas>

</div>

</body>

</html>

【HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)】相关文章:

HTML5 canvas实现雪花飘落特效

HTML5 Canvas中绘制矩形实例

HTML5 Canvas基本线条绘制的实例教程

实例教程 HTML5 Canvas 超炫酷烟花绽放动画实现代码

HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影

HTML5地理定位实例

HTML5中如何显示视频呢 HTML5视频播放demo

HTML如何实现文字绕排

HTML5 Canvas 起步(2) - 路径

HTML5 对各个标签的定义与规定:aside

精品推荐
分类导航