日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php 画虚线,HTML5 Canvas绘制圆点虚线实例_html5教程技巧

發布時間:2025/4/5 php 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php 画虚线,HTML5 Canvas绘制圆点虚线实例_html5教程技巧 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

HTML5 Canvas 提供了很多圖形繪制的函數,但是很可惜,Canvas API只提供了畫實線的函數(lineTo),卻并未提供畫虛線的方法。這樣的設計有時會帶來很大的不便,《JavaScript權威指南》的作者David Flanagan就認為這樣的決定是有問題的,尤其是在標準的修改和實現都比較簡單的情況下 (“…something that is so trivial to add to the specification and so trivial to implement… I really think you’re making a mistake here” — http://lists.whatwg.org/pipermail/whatwg-whatwg.org/2007-May/011224.html)。

在Stack Overflow上,Phrogz提供了一個自己的畫虛線的實現(http://stackoverflow.com/questions/4576724/dotted-stroke-in-canvas),嚴格的說,這是一個點劃線的實現(p.s. 我認為該頁面上Rod MacDougall的簡化版更好)。那么,如果需要畫圓點虛線(如下圖所示),應該怎么辦呢?

以下是我自己的實現,只支持畫水平的和垂直的圓點虛線,可以參考Phrogz與Rod MacDougall的方法來添加斜線描畫的功能。

復制代碼代碼如下:

var canvasPrototype = window.CanvasRenderingContext2D && CanvasRenderingContext2D.prototype;

canvasPrototype.dottedLine = function(x1, y1, x2, y2, interval) {

if (!interval) {

interval = 5;

}

var isHorizontal=true;

if (x1==x2){

isHorizontal=false;

}

var len = isHorizontal ? x2-x1 : y2-y1;

this.moveTo(x1, y1);

var progress=0;

while (len > progress) {

progress += interval;

if (progress > len) {

progress = len;

}

if (isHorizontal) {

this.moveTo(x1+progress,y1);

this.arc(x1+progress,y1,1,0,2*Math.PI,true);

this.fill();

} else {

this.moveTo(x1,y1+progress);

this.arc(x1,y1+progress,1,0,2*Math.PI,true);

this.fill();

}

}

}

本文原創發布php中文網,轉載請注明出處,感謝您的尊重!

總結

以上是生活随笔為你收集整理的php 画虚线,HTML5 Canvas绘制圆点虚线实例_html5教程技巧的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。