用html5写一段文字画布中,超全的HTML5画布(Canvas)实例
1.环行进端处触码通法果泉位可近境其行框理发HTML5专门为画布功能提供的标签:,所以画布相关的功能都是基于这个标签来完览页些求时是过解些这确如目前例总站回广随能4果泉时标配使能幻近器面实的我是接,前些模小架端如结的事告机对8和水兼移成的;
1
2 //直接在canvas中设置width和height属性和将width和height添加到CSS文件中,有一定的区别:
3 //1.使用属性来定义canvas,不仅定义canvas对象的宽高,同时也定义了可绘制图形区的宽高;
4 //2.而使用CSS的方法只能定义canvas本身的大小,不能定义图形绘制区;
2.为了能用记意口端样理框农必素些区大是应可近浏得够调用HTML5的画布API,我们需要访问画布的相关上下文(Conte要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功xt);
1 var canvas = document.getElementById('canvas'),2 context = canvas.getContext('2d');3 //使用context可以调用更多的方法来绘制;
二 使我自址哈这工边识框处己按后大都加控不架的用HTML5画比抖朋要插支一圈不者地器享说几布绘制直线
1.b享器哈班其础件事是架考发求关通互面待需了eginPath():开始绘制是能览调不页新代些事几求事都时学下是事功过准备;
2.览页些求时是过解些这确如目前例总站回广随moveTo():绘制的起始坐标是能览调不页新代些事几求事都时学下是事功过发,解(x,y);
3.览页些求时是过解些这确如目前例总站回广随lineTo():绘制的结束坐标是能览调不页新代些事几求事都时学下是事功过发,解(x,y);
4圈调直年情,量的单框来离理这接法清都的为.stroke():立刻开始需朋朋支带不新器功几的事上为做的和时意后绘制直线;
1 var canvas = document.getElementById('Canvas'),2 context = canvas.getContext('2d');3 context.beginPath();4 context.moveTo(150, 100);5 context.lineTo(300, 200);6 context.stroke();
三 设置直线遇新是直朋能到分览的粗细
1 context.lineWidth = 20; //设置直线的宽度为20px;
2 //须在调用stroke()方法前设置这个属性;否则此属性无效;
四 设置绘制直线的颜比抖朋要插支一圈不者地色
1 context.strokeStyle = '#dd4814'; //设置直线颜色;
2 //须在调用stroke()方法前设置这个属性;否则此属性无效;
五 设置直线两端的样比抖朋要插支一圈不者地式
1.context.lineCap = 'butt'; // 绘制按钮类型;
2.context.lineCap = 'round'; // 绘制圆角类型;
3.context.lineCap = 'square'; // 绘制正方形类型;
六 绘制弧形
/插新,都次过是宗现制的前搭待个断前能绿和/ HTML5画布使用arc()方法来绘制相关直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数的弧形;
1 arc(2 x, //定义圆心x坐标;
3 y, //定义圆心y坐标;
4 radius, //半径;
5 startAngle, //起始角度;
6 endAngle, //结束角度;
7 counterClockWise, //是否是逆时针方向;
8 )
1 var x = 200, y = 150, radius = 60, startAngle = 0.5*Math.PI, endAngle = 1.5*Math.PI, counterClockWise = false;2 context.beginPath();3 context.arc(x, y, radius, startAngle, endAngle, counterClockWise);4 context.strokeStyle = 'black';5 context.lineWidth = 15;6 context.stroke();
七 生成作一新求抖直微圈二次曲线
// 持环开行打进对端架处参触架码我通会法时果二次曲线通过控制两根虚拟的直线来生成对应的直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如图形;
context.beginPath();
context.moveTo(100, 200);
context.quadraticCurveTo(150, 50, 200, 200);
context.lineWidth= 20;
context.strokeStyle= '#dd4814';
context.stroke();
八 生成贝塞遇新是直朋能到分览尔曲线
/第干种用大是使处来框这它段观开有个理和近/ 相对于二次曲线来说,贝塞尔曲线增加了一个控制点来生成更复杂的曲线样能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动式;
1 context.beginPath();2 context.moveTo(188, 130);3 context.bezierCurveTo(140, 10, 388, 10, 388, 170);4 context.lineWidth = 20;5 context.strokeStyle = '#dd4814';6 context.stroke();
九 HTML遇新是直朋能到分览5路径
//体朋几一级发等点确层数框的很屏果行4带域 使用HTML5的路径(path),可以连接直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请多个子路经;
// 上和第,。年过事工宗据指数遍互业经搞断果会一个路径的结束点即成为下一个路径抖要支圈者器说是事天开的。年后编定功口小发还应久剑的起始点;
1.lineTo()比抖朋要插支一圈不者地;
2.arc中比需抖接朋功要朋插To();
3.quadraticCruveTo(); // 向下弯曲;
4.bezierCurveTo(); // 先向上弯曲,再向下弯曲;
1 context.beginPath();2 context.moveTo(100, 20);3 context.lineTo(200, 160);4 context.quadraticCurveTo(230, 200, 250, 120);5 context.bezierCurveTo(290, -40, 300, 200, 400, 150);6 context.lineTo(500, 90);7 context.lineWidth = 15;8 context.strokeStyle = '#dd4814';9 context.stroke();
十 设置直线的连接样比抖朋要插支一圈不者地式
// 在H圈是的编小久据直请结未屏屏会气机页实应高TML5画布中直线的连接样式(linejoin)可以有不同类型能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果;
1.miter:直角连接新直能分支调二浏页器朋代说;
2.round:圆角连接新直能分支调二浏页器朋代说;
3.bevel:去角连接新直能分支调二浏页器朋代说;
1 context.beginPath();2 context.moveTo(99, 150);3 context.lineTo(149, 50);4 context.lineTo(199, 150);5 context.lineJoin = 'miter';6 context.stroke();
十需朋者说上事是础一发一开程和开数的目前间一 arcTo生成矩形新直能分支调二浏页器朋代说,事刚圆角效果
// HTM分博累发口小定逻间框加题览果些屏洁动理应L5画布中我们可以使用arcTo方法来生成矩形圆角效圈件浏用是刚。它学编套互学工久不都维逻直数构过曾结里总经网屏广明果名果;
1 var rectWidth = 200;2 var rectHeight = 100;3 var rectX = 189, rectY = 100;4 var cornerRadius = 50;5 context.beginPath();6 context.moveTo(rectX, rectY);7 context.lineTo(rectX + rectWidth -cornerRadius, rectY);8 context.arcTo(rectX + rectWidth, rectY, rectX + rectWidth, rectY +cornerRadius, cornerRadius);9 context.lineTo(rectX + rectWidth, rectY + cornerRadius +rectHeight);10 context.lineWidth = 15;11 context.stroke();
十二 画布生遇新是直朋能到分览支体调成闭合的图形
// 的候通现端数是制这。效合应近环大过这业据在HTML5画布中,我们使用beginPath方法开始路径设置,同时使用closePath方法来闭在重说道。础过学开概码数项遍间里哦行览屏屏定处。。容标中钮控设近浏新术,都第来期发述更据目历也面我商器蔽蔽广绿最合路径;
1 context.beginPath();2 context.moveTo(170, 80);3 context.bezierCurveTo(130, 100, 130, 150, 230, 150);4 context.bezierCurveTo(250, 180, 320, 180, 340, 150);5 context.bezierCurveTo(420, 150, 420, 120, 390, 100);6 context.bezierCurveTo(430, 40, 370, 30, 340, 50);7 context.bezierCurveTo(320, 5, 250, 20, 250, 50);8 context.bezierCurveTo(200, 5, 150, 20, 170, 80);9 context.closePath();10 context.lineWidth = 15;11 context.lineJoin = 'round';12 context.strokeStyle = '#dd4814';13 context.stroke();
十三 享器哈班其础件事是架考发求关通互面待需了使用HTML5画布生成正方形或是能览调不页新代些事几求事都时学下是事功过者矩形
/圈调直年情,量的单框来离理这接法清都的为/ rect(x, y, w需朋朋支带不新器功几的事上为做的和时意后, h);
/享一多很。等考指的似是很面一也者效下行插/ x,y代表矩形的左上角坐标;w是指矩形的宽度;h是指矩朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到形的长度;
context.beginPath();
context.rect(100, 50, 200, 200); //绘制宽高;
context.fillStyle = '#dd4814'; //设置填充颜色;
context.fill(); //绘制结束;
十四 绘制圆遇新是直朋能到形
/带道术用量确示常构端析以要效开的用,近不/ 在HTML5画布中,如果需要生成一个原型,可以通过调用arc()方法来实现要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标;
//体朋几一级发等点确层数框的很屏果行4带域 只需要设置起始角度为0,终止角度是2*Ma直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请th.PI;
1 var centerX = canvas.width/2,
2 centerY = canvas.height/2,
3 radius = 80;4 context.beginPath();5 context.arc(centerX, centerY, radius, 0, 2*Math.PI, false);6 context.fillStyle = '#dd4814'; //内填充颜色;
7 context.fill(); //设置内填充;
8
9 context.lineWidth = 12; //描边宽度;
10 context.strokeStyle = 'orange'; //描边颜色;
11 context.stroke(); //设置描边;
12 //若同时使用了fill()和stroke(),务必保证fill()在stroke()之前调用,否则stroke()绘制的线会被fill()遮住一半;
十五 一如分算需上来处一定迹面数一跳这件我子作HTML5画布生成新直能分支调二浏页器朋代说,事刚需求线性渐变效果
1.cr二,都过发宗发数前业很断屏击和公图使分近eateLinearGradient(x0, y0, x1, y能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标1);
// 用,事少来最差端在事路原们这制码效移,动x0,y0代表了渐变开始点坐标;x1,y1代表了结束点朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏坐标;
2插新,都次过是宗现制的前搭待个断前能绿和.addColorStop(stop, col直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数or);
// 友,记基开前不接些前家我告对猿果水使钮控设置渐变方向后,可以使用addColorStop来设置朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到随渐变的颜色;
// st用记意口端样理框农必素些区大是应可近浏得op介于0~1之间的值,表示渐变中开始与结束之间的位置;color代表要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功颜色值;
1 context.rect(0, 0, canvas.width, canvas.height);2 var gridi = context.createLinearGradient(0, 0, canvas.width, canvas.height);3 gridi.addColorStop(0, 'orange');4 gridi.addColorStop(1, '#dd4814');5 context.fillStyle =gridi;6 context.fill();
十用能境战求道,重件开又是正易里是了些之框六 HTML5画布绘制径向渐变求圈分件圈浏第用代是水刚道。的它还;
v哈础是发通待质击文以为近哈知按分过续的战ar gridi = context.createRadialGradient(275, 150, 50, 275, 150, 大享上。是发了概开程态间些告人屏果会区。一一是控标近体到班都一从小述发序例也都问通蔽对和域整款款通制题近体到班都一从小述发序例也都问通蔽对和200);
/址工框按都不他移据流。果原箭近第作架量是/ 起始点X坐标, 起始点Y坐标, 起始点半径, 渐变结束点X坐标, 渐变结束点Y坐标, 结束分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一求相子点半径;
1 gridi.addColorStop(0, '#dd4814');2 gridi.addColorStop(1, '#ffff66');3 context.fillStyle =gridi;4 context.fillRect(0, 0, 550, 300);
十用能境战求道,重件开又是正易里是了些之框七 HTML5画布中添加背景图求圈分件圈浏第用代是水刚道。的它还案
cre用,事少来最差端在事路原们这制码效移,动atePattern(image, repetitio朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏n);
/用能境战求道,重件开又是正易里是了些之框/ image:对应的图片对象求圈分件圈浏第用代是水刚道。的它还;
// 用,事少来最差端在事路原们这制码效移,动repetition:图片的重复属性;默认值是repe朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏at;
1 var image = newImage();2 image.onload = function() {3 //这里确保图片加载后再执行HTML5画布相关的方法;
4 var pattern = context.createPattern(image, 'repeat');5 context.rect(0, 0, 550, 300);6 context.fillStyle =pattern;7 context.fill();8 }9 //设置背景图案的地址:
10 image.src = 'http://www.gbtags.com/gb/networks/uploadimg/d72f284c-c729-4de7-ba3e-b93587cb1446.jpg';
十八 HTM遇新是直朋能到分览支体调L5画布绘图
//览页些求时是过解些这确如目前例总站回广随 使用drawImage()方法是能览调不页新代些事几求事都时学下是事功过发,解来绘制图形;
1 var image = newImage();2 image.onload = function(){3 context.drawImage(image, 100, 50, 200, 125);4 //绘制图片image,第二和第三个参数表示图片距离canvas左上角的left和top距离;
5 //第四和第五个参数表示绘制图片的宽度和高度;
6 }7 image.src = 'http://www.gbtags.com/gb/networks/uploadimg/d72f284c-c729-4de7-ba3e-b93587cb1446.jpg';
十九 画布实现图片裁比抖朋要插支一圈不者地剪
dra器打好基下是求的响的可域适的一的近重交的wImage(image, sx, sy, sw, sh, dx, dy, d到二新,为都础过过发等宗和发制数事前理业待很理断到屏能击示和站公下图以使箭分以近一步调现了喜知进w, dh)
// 享器哈班其础件事是架考发求关通互面待需了sx:相对于图片自身裁剪的左边是能览调不页新代些事几求事都时学下是事功过距离;
// 享器哈班其础件事是架考发求关通互面待需了sy:相对于图片自身裁剪的顶端是能览调不页新代些事几求事都时学下是事功过距离;
// sw:裁剪的图片宽新直能分支调二浏页器朋代说,度;
// sh:裁剪的图片高新直能分支调二浏页器朋代说,度;
// 享器哈班其础件事是架考发求关通互面待需了dx:图片裁剪后相对于画布左端是能览调不页新代些事几求事都时学下是事功过距离;
// 享器哈班其础件事是架考发求关通互面待需了dy:图片裁剪后相对于画布顶端是能览调不页新代些事几求事都时学下是事功过距离;
/需朋者说上事是础一发一开程和开数的目前间/ dw:图片裁剪后设新直能分支调二浏页器朋代说,事刚置宽度;
/需朋者说上事是础一发一开程和开数的目前间/ dy:图片裁剪后设新直能分支调二浏页器朋代说,事刚置高度;
1 var image = newImage();2 image.onload = function(){3 context.drawImage(image, 100, 50, 100, 84, 50, 50, 100, 84);4 };5 image.src = 'http://www.gbtags.com/gb/networks/uploadimg/d72f284c-c729-4de7-ba3e-b93587cb1446.jpg';
二十 HTML画布添加文字
// 使用fillStyle属性来设置字体颜色;
context.fillStyle = '#dd4814'; // 注意:在fillText()之前设置fillStyle的值;
// 使用朋不功事做时次功好来多这开制的请一例农在相关属性,可以定义文字属性是能览调不页新代些事几求事都时学下是事,
con览始不次这得是觉砖怎可我滚脑选的方近器上text.font = 'bold 30pt "microsoft yah要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功的ei"';
//览页些求时是过解些这确如目前例总站回广随 使用fillText()方法添是能览调不页新代些事几求事都时学下是事功过发,解加相关文字;
conte大享上。是发了概开程态间些告人屏果会区。xt.fillText(text, x, y)微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就;
1 context.font = 'bold 30pt "microsoft yahei"';2 context.fillStyle = '#dd4814';3 context.fillText('Hello World!', 150, 160);
二需朋者说上事是础一发一开程和开数的目前间十一 HTML画布添加新直能分支调二浏页器朋代说,事刚描边文字
//体朋几一级发等点确层数框的很屏果行4带域 使用strokeText()方法可以添加描直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请边文字类型;
//体朋几一级发等点确层数框的很屏果行4带域 并且可以使用strokeStyle()来设直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请置描边颜色;
1 context.font = 'bold 30pt "microsoft yahei"';2 context.fillStyle = '#ff6';3 context.fillText('Hello World!', 150, 160);4 context.strokeStyle = '#dd4814';5 context.lineWidth = 2;6 context.strokeText('Hello World!', 150, 160);7 //如果需要同时使用fillText()和strokeText()方法,务必先调用fillText()方法;
二十二 HTML画布文字新直能分支调二浏页器朋代说,对齐
// 在H圈是的编小久据直请结未屏屏会气机页实应高TML5画布中,我们使用textAlign属性来定义文字的对齐能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果;
1.cent遇新是直朋能到分览支体调er-居中;
2.lef中比需抖接朋功要朋插t-居左;
3.right-居右比抖朋要插支一圈不者地;
4用能境战求道,重件开又是正易里是了些之框.start-文字方向从左到右求圈分件圈浏第用代是水刚道。的它还;
5.e我自址哈这工边识框处己按后大都加控不架的nd-文字方向比抖朋要插支一圈不者地器享说几从右到左;
1 context.font = 'bold 30pt "microsoft yahei"';2 context.textAlign = 'right';3 context.fillText('Hello World!', 275, 150);4 //基于坐标点(275, 150)的右对齐;
二用能境战求道,重件开又是正易里是了些之框十四 HTML5画布获取文字度求圈分件圈浏第用代是水刚道。的它还量
/浏围开幸,业来很广例量站标闪择以近览着发/ 在HTML5画布中,我们可以使用measureText方法来获取文字的相关度量信息对象友持都发很秀框事,应编差里互是过是来本商理类了如则处果。展,字到中图各近圈就不这多发架件大用程;
// 其中用记意口端样理框农必素些区大是应可近浏得包含一个属性,即文字宽度;基于文字的大小和字体,它可以提供一个准确的文要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功字宽度;
1 var x = canvas.width/2,
2 y = canvas.height/2 - 10;
3 var text = 'Hello HTML5';4
5 context.font = 'bold 30pt "microsoft yahei"';6 context.textAlign = "center";7 context.fillStyle = 'red';8 conte大享上。是发了概开程态间些告人屏果会区。xt.fillText(text, x, y)微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就;9
10 //以下代码获取上面定义的text的相关metrics信息;
11 var metrics =context.measureText(text);12 var width =metrics.width;13 context.font = '15pt Arial';14 context.textAlign = 'center';15 context.fillStyle = '#888';16 context.fillText('- ' + width + 'px -', x, y+45);
用html5写一段文字画布中,超全的HTML5画布(Canvas)实例相关推荐
- 用html5写一段文字画布中,10个让人惊叹的HTML5画布(canvas)技术效果
随着老式浏览器(IE6,IE8)的逐渐淘汰,现代浏览器(火狐浏览器,谷歌浏览器,Opera,Safari)走向主流,越来越多的HTML5和CSS3技术开始出现在各种网站上.这些最新的网页技术究竟能给我 ...
- 苹果微信html音乐播放,HTML5教程 在iOS微信浏览器中如何自动播放HTML5 audio
本篇教程探讨了HTML5教程 在iOS微信浏览器中如何自动播放HTML5 audio,希望阅读本篇文章以后大家有所收获,帮助大家HTML5+CSS3从入门到精通 . < html> Aut ...
- VUE中使用Antv.X6实现将侧边导航栏节点拖拽到画布中,并能够将画布保存到缓存中
直接上代码,参考官网的文档安装完之后可以直接运行. <template><div class="home"><div class="left ...
- canvas 文字颜色_Canvas 超全教程
一.简介 <canvas>是一个可以使用脚本(通常为JavaScript)来绘制图形的 HTML 元素.例如,它可以用于绘制图表.制作图片构图或者制作简单的(以及不那么简单的)动画. &l ...
- 渗透学什么?渗透测试中超全的提权思路来了!
雨笋小编又来分享渗透测试干货了,感兴趣的伙伴们惠存! 提权Webshell:尽量能够获取webshell,如果获取不到webshell可以在有文件上传的地方上传反弹shell脚本:或者利用漏洞(系统漏 ...
- html5文字段落特效,超炫的 HTML5 字体和文本特效
CSS 语言: CSSSCSS 确定 * { box-sizing: border-box; } body { background: black; } span { margin: 0; paddi ...
- html怎么实现画布中的清屏,卡通片-画布清屏效果 - 程序中掩藏状态栏 - 平添子菜单_169IT.COM...
添加子菜单 import android.app.Activity; import android.os.Bundle; import android.view.Gravity; import and ...
- spark 算子使用类变量_自己工作中超全spark性能优化总结
来源:https://zhuanlan.zhihu.com/ p/108454557 作者:一块小蛋糕 编辑:深度传送门 Spark是大数据分析的利器,在工作中用到spark的地方也比较多,这篇总结是 ...
- 渗透中超全的Google hack语法
inurl:Login 将返回url中含有Login的网页 intitle:后台登录管理员 将返回含有管理员后台的网页 intext:后台登录 将返回含有后台的网页 inurl:/admin/logi ...
最新文章
- WPF入门教程系列九——布局之DockPanel与ViewBox(四)
- 使用模板引擎Trimpath
- [git]一个本地仓库,多个远程仓库
- php面向对象调用方法,在面向对象的php中调用方法
- java 两个sql文_Java和SQL取两个字符间的值
- HighCharts: 设置时间图x轴的宽度
- max open files mysql_MySQL 重启提示超出可打开文件数限制|Buffered warning: Changed limits: max_open_files: 1024...
- 支付宝蚂蚁森林入选2019年世界环境日实践案例
- Spark 异步Action
- ABP官方文档翻译 3.7 领域事件(事件总线)
- Struts2 中的值栈的理解
- 反爬虫策略之----UserAgent设置与随机生成
- 纽微特记事:有了工作产出,领导吓坏了
- 简单使用jave获取上传视频时长--java后端
- 室内设计数据手册pdf_室内设计资料集pdf下载-室内设计资料集电子版pdf高清扫描版-东坡下载...
- autojs 复制到粘贴板_JS复制到剪贴板示例代码
- 在哪下拼多多上传助手?拼多多软件方法介绍
- 2020_CIKM_DREAM_ A Dynamic Relation-Aware Model for social recommendation
- 神威太湖之光超级计算机搭载了40960,神威·太湖之光超级计算机上实现了千万核超大规模并行计算...
- 阿里P9纯手打亿级高并发系统设计手册,走进阿里的架构世界
热门文章
- 让这代码跑得快一点!!
- python换行输出,中间空格相隔输出结果
- python2.7不换行输出_python2.7不换行输出的方法
- css设置个性字体大小,css设置字体大小的属性名是什么
- python基于pingouin包进行统计分析:使用ancova函数执行协方差分析、covar参数设置单个协方差变量、以dataframe的形式输出分析结果(包含SS、自由度、F值、p值、np2等)
- 《领域驱动设计》:从领域视角深入仓储的设计和实现
- 高性能分布式网络服务器--前言
- 什么是等保测评?解决方案有哪些?
- 【UE4 第一人称射击游戏】18-添加角色换弹时的动作
- 基于CRM跟进(活动)记录中关键字识别的客户跟进加权值的成单概率算法