中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

突破canvas語法限制 讓他支持鏈式語法
來源:易賢網 閱讀:2346 次 日期:2016-08-01 15:53:01
溫馨提示:易賢網小編為您整理了“突破canvas語法限制 讓他支持鏈式語法”,方便廣大網友查閱!

突破canvas語法限制,有很多的朋友可能還不相信,本文將詳細介紹如何讓canvas支持鏈式語法,需要了解的朋有可以參考下

先來看一段正常的canvas畫圖語法:

代碼如下:

ctx.arc(centerX,centerY,radius,0,PI*2,true);

ctx.shadowColor = 'rgba(0,0,0,0.5)';

ctx.shadowBlur = "10";

ctx.fill();

ctx.beginPath();

ctx.shadowColor = 'rgba(0,0,0,0)';

ctx.moveTo(centerX-radius,centerY);

ctx.lineTo(centerX-radius,centerY - 50);

ctx.lineTo(centerX+radius,centerY - 50);

ctx.lineTo(centerX+radius,centerY);

// ctx.lineTo(centerX-radius,centerY);

ctx.fill();

ctx.beginPath();

ctx.fillStyle = 'rgba(255,0,0,1)';

ctx.arc(centerX,centerY-50,radius,0,PI*2,true);

ctx.fill();

我對canvas原生語法不爽的有兩點:1是每句前面都有寫ctx(即canvas的context2d對象),2是每個函數或屬性都要占一行,浪費空間。

我對jQuery的鏈式語法很欣賞,比如:

代碼如下:

$('#div1').show(300).html(p).delay(3000).slideUp(300).remove();

所以,我也想用這種語法來進行canvas繪圖:

代碼如下:

ctx.moveTo(500,0).lineTo(500,500).strokeStyle('#f00').stroke();

有個辦法就是模擬一個context2d對象,這個對象支持所有的原生context2d方法,但又支持鏈式。

不過,代碼不能太多,多了就沒人喜歡用了。

下面就是完整的代碼段,這個“類”我取名為XtendCanvas(又是以X開頭的喲):

代碼如下:

// 讓canvas支持鏈式語法,來自十年燈

~function () {var pro = ['save','restore', 'scale', 'rotate', 'translate', 'transform', 'createLinearGradient', 'createRadialGradient', 'getLineDash', 'clearRect', 'fillRect', 'beginPath', 'closePath', 'moveTo', 'lineTo', 'quadraticCurveTo', 'bezierCurveTo', 'arcTo', 'rect', 'arc', 'fill', 'stroke', 'clip', 'isPointInPath', 'measureText', 'clearShadow', 'fillText', 'strokeText', 'strokeRect', 'drawImage', 'drawImageFromRect', 'putImageData', 'createPattern', 'createImageData', 'getImageData', 'lineWidth','strokeStyle','globalAlpha','fillStyle','font','shadowOffsetX','shadowOffsetY','shadowBlur','shadowColor','lineCap','lineJoin','miterLimit'];

function XtendCanvas (canvas) {

var ctx = canvas.getContext('2d'),

fn = function(){},

fnP = fn.prototype;

for(var j = 0,p=pro[0];p;p=pro[j++]) {

fn.prototype[p] = function (p) {

return function () {

var args = Array.prototype.slice.call(arguments);

// console.log(args);

if(typeof ctx[p] == 'function') {

ctx[p].apply(ctx,args);

} else {

ctx[p] = args+'';

}

return fnP;

};

}(p);

}

return new fn;

};

window.XtendCanvas = XtendCanvas;

}();

使用方法很簡單,給他傳一個canvas對象,他就會返回一個類似context2d的對象,你可以像普通的context2d一樣使用,但不同的是,他支持鏈式語法了:

代碼如下:

var cvs = document.getElementById('cvs');

var ctx = XtendCanvas(cvs);

ctx.moveTo(500,0).lineTo(500,500).strokeStyle('#f00').stroke();

這樣一來你就可以把所有操作都放在一句話里,你也可以隨時中斷,做其他的事,然后繼續。

這段代碼并不是對canvas的增強,只是單純的讓他支持鏈式語法了。但勝在代碼少,可以嵌入到任何JS庫中,在此我希望能得到你的一個“推薦”

代碼中肯定有值得改進的地方,大家可以自行完善。但——吃水不忘挖井人,希望大家記得我,最重要的是思路,對吧?下面就是思路:

大家可以看到,代碼中最長的部分,是那個保存方法名的數組pro,核心代碼反而很短。為什么我要建這么一個數組呢?

本來我也想直接從CanvasRenderingContext2D繼承所有原生方法,但每個瀏覽器下面遍歷這個CanvasRenderingContext2D,結果都不一致。如果我把他們直接繼承,那么當你想用chrome中的方法套在firefox里執行,就會報錯。

所以我只是把CanvasRenderingContext2D中的通用的,無異議的方法與屬性名提取了出來,沒辦法,只有建一個固定的數組——大家可以自行決定往里面添加你的方法。

方法與屬性提取出來了,接著就是把原生的方法加在我的新對象上。我建了一個叫fn的空函數,放置我的方法。

由于數組中的這些元素既有函數,也有屬性,所以我在循環中判斷了他是否是一個函數,如果是函數,就帶參數執行;不是函數——那么就肯定是屬性了,就把參數賦給這個屬性。

這樣大家在碰到設置canvas屬性的時候,就不用中斷鏈了,直接把屬性值當參數傳進去就行了,比如:

代碼如下:

ctx.strokeStyle('#f00')

最后,關鍵的關鍵,就是返回fn,這招是從jQuery學來的,是支持鏈式語法的關鍵。

這段中用到了匿名函數,閉包,原型,以及我以前文章講過的奇怪的for循環。

說起來好像挺簡單的,不過我實在是想了很久,希望對大家有用。

在寫代碼的過程中,我發現chrome的做法很不錯,他有一串以set開頭的函數,如setStrokeColor,setLineCap等函數,給他們傳參數,就可以替代對應的strokeStyle和lineCap等屬性,也就是說,他的canvas里面就全是函數而沒有屬性了那樣的話我就不用判斷是函數還是是屬性了。但firefox里面沒有這些,所以我還是只能用前面的思路。

我也把那一串set函數給放出來吧:

代碼如下:

var bak = ['setTransform','setAlpha', 'setCompositeOperation', 'setLineWidth', 'setLineCap', 'setLineJoin', 'setMiterLimit', 'setLineDash','setShadow','setStrokeColor','setFillColor'];

他們的用處一看就懂。你也可以選擇一些加入前面代碼的pro數組中。

更多信息請查看網頁制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
激情91久久| 亚洲国产精品一区在线观看不卡| 在线中文字幕一区| 日韩一区二区电影网| 免费看亚洲片| 亚洲国产精品久久久久秋霞不卡| 国产欧美一区二区三区在线看蜜臀| 久久久精品日韩| 国产精品99免费看 | 亚洲激情精品| 久久精品视频在线| 亚洲专区一区| 亚洲婷婷综合久久一本伊一区| 亚洲精品国产精品国产自| 先锋影音久久| 久久国产精品久久久久久久久久| 欧美中文字幕| 欧美成人免费在线观看| 欧美日韩在线另类| 国产精品老牛| 亚洲第一在线综合网站| 亚洲一区二区三区四区在线观看 | 久久精品久久综合| 永久久久久久| 国产精品久久久久久久久免费桃花 | 国产模特精品视频久久久久 | 亚洲男女毛片无遮挡| 亚洲综合久久久久| 久久人人精品| 欧美日韩国产精品一卡| 亚洲福利av| 欧美日韩综合久久| 欧美午夜电影完整版| 国内精品伊人久久久久av影院| 国产主播在线一区| 欧美午夜免费| 国产自产2019最新不卡| 国产精品v亚洲精品v日韩精品| 欧美一区二区在线视频| 欧美区一区二| 亚洲第一区在线| 欧美高清在线播放| 亚洲黄色精品| 欧美精品激情blacked18| 亚洲精品国产欧美| 国产精品电影观看| 日韩小视频在线观看专区| 久久成人资源| 亚洲国产高清一区二区三区| 欧美国产一区视频在线观看| 亚洲系列中文字幕| 国产区精品在线观看| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲激情在线激情| 欧美日韩三级在线| 亚洲精品综合久久中文字幕| 久久在线免费视频| 亚洲欧美另类国产| 亚洲国产欧美日韩| 国产欧美一级| 国产精品久在线观看| 亚洲卡通欧美制服中文| 欧美三日本三级少妇三99| 在线综合亚洲| 欧美理论片在线观看| 亚洲电影免费观看高清完整版在线观看| 亚洲一区二区三| 91久久视频| 欧美日韩国语| 亚洲欧美一区二区原创| 樱花yy私人影院亚洲| 久久精品成人欧美大片古装| 国产精品视频免费观看www| 亚洲精品永久免费精品| 国产日本精品| 久久国产欧美精品| 国内精品伊人久久久久av一坑| 久久久久久久999| 国产欧美一区二区三区在线看蜜臀| 亚洲色诱最新| 亚洲少妇最新在线视频| 国产精品国产三级国产专播品爱网| 一卡二卡3卡四卡高清精品视频| 国产精品成av人在线视午夜片| 亚洲激情第一页| 亚洲开发第一视频在线播放| 在线观看视频欧美| 红桃av永久久久| 国产亚洲欧美一区在线观看| 国产精品黄色| 久久久久综合一区二区三区| 亚洲精选一区二区| 国产自产高清不卡| 国产午夜精品全部视频播放| 欧美亚男人的天堂| 欧美国产日韩精品免费观看| 久久精品国产亚洲5555| 99精品视频一区| 一区二区三区高清| 亚洲国产成人91精品| 激情久久久久久久久久久久久久久久| 久久精品国产第一区二区三区最新章节| 亚洲国产成人久久综合| 亚洲日本成人在线观看| 亚洲直播在线一区| 久久国产乱子精品免费女| 亚洲视频免费在线观看| 亚洲伦理在线观看| 在线亚洲+欧美+日本专区| 亚洲性人人天天夜夜摸| 亚洲视频在线观看免费| 午夜精品久久久久久久男人的天堂 | 亚洲精品一区二区三| 亚洲欧美激情在线视频| 欧美成人精品h版在线观看| 国产精品久久久久9999高清| 亚洲国产综合视频在线观看| 99视频+国产日韩欧美| 99www免费人成精品| 久久免费国产精品1| 国产精品久久久久久福利一牛影视| 最新日韩精品| 久热精品视频在线免费观看| 国产麻豆日韩欧美久久| 在线视频欧美日韩精品| 久久精品成人| 久久精品盗摄| 亚洲国产影院| 久久久激情视频| 国产毛片一区| 亚洲女优在线| 在线观看av不卡| 久久久7777| 国产精品人成在线观看免费| 亚洲人www| 欧美—级在线免费片| 99精品欧美一区二区三区| 欧美日韩国产一区二区三区地区| 一区二区三区欧美在线| 伊人久久大香线蕉av超碰演员| 欧美视频一区二区| 久久精品人人爽| 亚洲人人精品| 国产欧美日韩中文字幕在线| 久久er精品视频| 亚洲电影免费在线观看| 国产精品高清在线观看| 午夜精品久久久| 亚洲国产成人av| 欧美日韩精品一区| 久久免费的精品国产v∧| 欧美一级免费视频| 一区二区免费在线观看| 亚洲美女网站| 亚洲午夜精品国产| 国产精品sss| 欧美日韩高清免费| 男人天堂欧美日韩| 亚洲视频第一页| 最近看过的日韩成人| 国产美女诱惑一区二区| 国产九九视频一区二区三区| 国产精品美女久久久久av超清| 久久在线播放| 亚洲欧美日韩在线观看a三区| 在线国产日韩| 好看的日韩av电影| 国产九色精品成人porny| 欧美风情在线观看| 欧美激情精品久久久久| 久久视频在线看| 久久久高清一区二区三区| 免费视频一区二区三区在线观看| 午夜一区二区三区在线观看| 一区二区三区高清不卡| 亚洲国产老妈| 日韩天堂在线观看| 99在线精品视频| 亚洲素人在线| 久久久国产一区二区三区| 久久综合九色综合欧美狠狠| 久久久久五月天| 久久国产精品久久久| 欧美成人高清| 欧美日韩在线电影| 国产精品久久久久久福利一牛影视| 欧美三区不卡| 国产乱码精品一区二区三区忘忧草 | 一区二区三区高清在线 | 在线播放不卡| 亚洲视频精品| 国产精品扒开腿爽爽爽视频| 娇妻被交换粗又大又硬视频欧美| 亚洲一区在线直播| 国产精品免费看| 国产女精品视频网站免费| 亚洲性感美女99在线| 亚洲系列中文字幕| 欧美日韩成人激情| 一区二区三区我不卡|