成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 清除canvas畫布內(nèi)容(點擦除+線擦除)

清除canvas畫布內(nèi)容(點擦除+線擦除)

熱門標簽:電話機器人電銷系統(tǒng)掙話費 高德地圖標注地點糾錯 如何獲取地圖標注客戶 南昌仁和怎么申請開通400電話 拓展地圖標注 機器人外呼系統(tǒng)存在哪些能力 平?jīng)龅貓D標注位置怎么弄 電話機器人黑斑馬免費 只辦理400電話

清空canvas畫布內(nèi)容

1、重置寬或高

由于canvas每當高度或?qū)挾缺恢卦O時,畫布內(nèi)容就會被清空,因此可以用以下方法清空:(此方法僅限需要清除全部內(nèi)容的情況)

var c=document.getElementById("myCanvas");  
c.width=c.width;

2、clearRect

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.fillStyle="red";
ctx.fillRect(0,0,300,150);
ctx.clearRect(20,20,100,50);

3、globalCompositeOperation

引用globalCompositeOperation()函數(shù),這個函數(shù)是用來在畫布上組合顏色,我們可以利用這個原理,疊加(數(shù)學上的"或"原理)來制作橡皮。

首先看看globalCompositeOperation屬性可以設置的值有哪些,分別是什么效果:

描述
source-over 默認。在目標圖像上顯示源圖像。
source-atop 在目標圖像頂部顯示源圖像。源圖像位于目標圖像之外的部分是不可見的。
source-in 在目標圖像中顯示源圖像。只有目標圖像內(nèi)的源圖像部分會顯示,目標圖像是透明的。
source-out 在目標圖像之外顯示源圖像。只會顯示目標圖像之外源圖像部分,目標圖像是透明的。
destination-over 在源圖像上方顯示目標圖像。
destination-atop 在源圖像頂部顯示目標圖像。源圖像之外的目標圖像部分不會被顯示。
destination-in 在源圖像中顯示目標圖像。只有源圖像內(nèi)的目標圖像部分會被顯示,源圖像是透明的。
destination-out 在源圖像外顯示目標圖像。只有源圖像外的目標圖像部分會被顯示,源圖像是透明的。
lighter 顯示源圖像 + 目標圖像。
copy 顯示源圖像。忽略目標圖像。
xor 使用異或操作對源圖像與目標圖像進行組合。

<!DOCTYPE html>
<html>
<head>
<style>
canvas
{
border:1px solid #d3d3d3;
margin-right:10px;
margin-bottom:20px;
}
</style>
</head>
<body>

<script>

var gco=new Array();
gco.push("source-atop");
gco.push("source-in");
gco.push("source-out");
gco.push("source-over");
gco.push("destination-atop");
gco.push("destination-in");
gco.push("destination-out");
gco.push("destination-over");
gco.push("lighter");
gco.push("copy");
gco.push("xor");
for (n=0;n<gco.length;n++)
    {
    document.write("<div id='p_" + n + "' style='float:left;'>" + gco[n] + ":<br>");
    var c=document.createElement("canvas");
    c.width=120;
    c.height=100;
    document.getElementById("p_" + n).appendChild(c);
    var ctx=c.getContext("2d");
    ctx.fillStyle="blue";
    ctx.fillRect(10,10,50,50);
    ctx.globalCompositeOperation=gco[n];
    ctx.beginPath();
    ctx.fillStyle="red";
    ctx.arc(50,50,30,0,2*Math.PI);
    ctx.fill();
    document.write("</div>");
    }

</script>

</body>
</html>

可以看出如果設置成destination-out,就可以清除canvas現(xiàn)有的像素點的圖像。

清除繪制到畫布上的線條(點擦除,線擦除)

  在我最近實現(xiàn)的項目中有畫筆功能, 同時畫筆畫出的線條可以被橡皮擦擦除,有點擦除和線擦除兩種方式。

  使用以上兩種方法也可以,但是如果這些線條不止繪制一次的話呢,中間有其他操作(例如繪制的內(nèi)容變換一次后)那上面的方法就不容易做到了,因為要反復繪制存儲每次擦除后的數(shù)據(jù),簡單的為了能達到該目的,可以將整個canvas畫布轉(zhuǎn)化成base64編碼的image,后面再次繪制的時候把這個image數(shù)據(jù)再繪制到canvas上,可以繼續(xù)在這個canvas上進行繪制和擦除內(nèi)容。但是怎么樣也不好做到線擦除的功能了!

  下面介紹另外一種存儲繪制路徑點坐標的方法去實現(xiàn)繪制線條后的點擦除和線擦除的功能。

  首先介紹下存儲線條的數(shù)據(jù)結(jié)構(gòu),之前寫的一篇《js實現(xiàn)存儲對象的數(shù)據(jù)結(jié)構(gòu)hashTable和list》大家可以先大致看看hash結(jié)構(gòu)的實現(xiàn),但是key和value快速查找的優(yōu)勢需要清楚。另外在canvas畫的各種形狀和線條,我們是如何知道點擊到哪個元素哪條線?《軟件項目技術(shù)點(4)——實現(xiàn)點擊畫布上元素》這篇博客里有說明實現(xiàn)原理。

1. 線條存儲及繪制

項目中我存儲的線條hash結(jié)構(gòu)的對象如下:

展開第一個線條key值為“#8c471a”的具體信息如下,value值其中有colorKey,lineColor,lineWidth,以及最重要的List結(jié)構(gòu)的points對象,是一個存儲了該線條所有點坐標集合的List對象。

下面的一段代碼,實現(xiàn)了繪制該線條到畫布。使用二次貝塞爾函數(shù)使得繪制出來的線條流暢平滑沒有折痕,當只有一個點時可繪制出一個圓點。

var count = this.points.length();
                var p: Core.Point = this.points.get(0);
                if (isDrawHit) {
                    ctx.strokeStyle = this.colorKey;
                }
                else {
                    ctx.strokeStyle = this.lineColor;
                }
                ctx.lineCap = "round";
                ctx.lineJoin = 'round';//轉(zhuǎn)折的時候不出現(xiàn)尖角
                if (ctx.canvas.id == "hitCanvas")
                    ctx.lineWidth = this.lineWidth + eraserRadius;//擴大hit上線條的范圍,橡皮半徑
                else
                    ctx.lineWidth = this.lineWidth;
                ctx.beginPath();
                if (count >= 2) {
                    ctx.moveTo(p.x, p.y);
                    for (var i = 1; i < count - 2; i++) {
                        // p = this.points.get(i);
                        // ctx.lineTo(p.x, p.y);
                        if (this.points.get(i).x == this.points.get(i + 1).x && this.points.get(i).y == this.points.get(i + 1).y)
                            continue;
                        var c = (this.points.get(i).x + this.points.get(i + 1).x) / 2;
                        var d = (this.points.get(i).y + this.points.get(i + 1).y) / 2;
                        ctx.quadraticCurveTo(this.points.get(i).x, this.points.get(i).y, c, d); //二次貝塞曲線函數(shù)
                    }
                    // For the last 2 points
                    if (count >= 3) {
                        ctx.quadraticCurveTo(
                            this.points.get(i).x,
                            this.points.get(i).y,
                            this.points.get(i + 1).x,
                            this.points.get(i + 1).y
                        );
                    } else if (count >= 2) {
                        ctx.lineTo(this.points.get(1).x, this.points.get(1).y);
                    }
                    ctx.stroke();
                } else {
                    if (isDrawHit) {
                        ctx.fillStyle = this.colorKey;
                    }
                    else {
                        ctx.fillStyle = this.lineColor;
                    }
                    if (ctx.canvas.id == "hitCanvas")
                        var radius = this.lineWidth + eraserRadius;//擴大hit上線條的范圍,橡皮半徑
                    else
                        var radius = this.lineWidth;
                    ctx.arc(this.points.get(0).x, this.points.get(0).y, radius, 0, 2 * Math.PI);
                    ctx.fill();
                }

 其中繪制到hitCanvas上的時候?qū)ineWidth擴大加上了eraserRadius(圓形橡皮擦半徑),下圖即為繪制到hitCanvas上的colorKey顏色線條,每個線條顏色值是上圖中的key值colorKey。另外線條粗細明顯比上面的白色線條要粗很多,因為橡皮擦是個cur鼠標樣式它的半徑很大,但獲取的鼠標點擊位置還只是一個像素點坐標,所以為了擴大鼠標點到線條上的范圍將其變粗。

 2. 線擦除和點擦除

這樣線擦除就很容易實現(xiàn),只需要找到橡皮擦點到畫布上的坐標點的色值,就其從hash集合中根據(jù)colorKey刪除掉該項,即實現(xiàn)了刪除整條線。

點擦除就需要考慮到從兩端擦除或者從中間擦除的情況:

         if (that.isErasePoint) {
                      line.points.foreach(function (i, p) {
                          //橡皮擦距離該線條上點的距離是否在橡皮擦半徑范圍內(nèi)
                          if (Math.pow(p.x - point.x, 2) + Math.pow(p.y - point.y, 2) <= Math.pow(eraserRadius, 2)) {
                              isSeparate = true;
			      //已經(jīng)找到橡皮擦半徑范圍內(nèi)的點,該點不存入兩個集合中的任何一個
                          } else {
                              if (isSeparate)
			      //找到后將之后的點存入另一個點集合points中
                                  points2.add(p);
                           else//找到之前將點存入點集合points1中
                                 points.add(p);
                         }
                     })
                     //遍歷完線條points上的所有點后。根據(jù)points1和points2是否為空處理點擦除后的線條
                    if (points1.length() >= 1 && points2.length() >= 1) {
		    //points1和points2都不為空,說明從中間擦除變?yōu)閮蓷l線
                         var preLine = editor.commonEditLogic.clonePenLine(line);
                        line.points = points1;
                         var linePen = editor.bdCanvas.elementFactory.createPenLine(point, line.lineWidth, line.lineColor);
                         linePen.points = points2;                                  
                           editor.bdCanvas.activeElement.setPenLine(linePen.colorKey, linePen);
                     } 
		     else if (points1.length() == 0 && points2.length() >= 1)
		     {
		           //從一端擦除
                         line.points = points2;
                     }
		     else if (points1.length() >= 1 && points2.length() == 0) 
		     {
		         //從一端擦除
                         line.points = points1;
                     } 
		     else if (points1.length() == 0 && points2.length() == 0)
		     {
		            //線條上的點全部被擦除,刪除該線條
                            editor.bdCanvas.activeElement.delPenLine(line.colorKey);               
			    }
                     editor.courseware.currentBlackboard.draw(false, true);
               }

到此這篇關(guān)于清除canvas畫布內(nèi)容(點擦除+線擦除)的文章就介紹到這了,更多相關(guān)canvas畫布清除內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

標簽:池州 漯河 新疆 永州 遼源 棗莊 西藏 青島

巨人網(wǎng)絡通訊聲明:本文標題《清除canvas畫布內(nèi)容(點擦除+線擦除)》,本文關(guān)鍵詞  清除,canvas,畫布,內(nèi)容,點,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《清除canvas畫布內(nèi)容(點擦除+線擦除)》相關(guān)的同類信息!
  • 本頁收集關(guān)于清除canvas畫布內(nèi)容(點擦除+線擦除)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美日韩国产高清一区二区| 欧美日韩女优| 在线观看欧美激情| 亚洲激情视频在线观看| 欧美人伦禁忌dvd放荡欲情| 69久久夜色精品国产69乱青草| 国产一区二区视频在线免费观看| 一本一道久久a久久精品综合| av不卡一区二区| 日韩欧美在线电影| 国产91白丝在线播放| 久久综合丝袜日本网| 在线观看av日韩| 日本黄色小视频在线观看| 久久av二区| 日韩午夜黄色| 日韩国产在线不卡视频| 亚洲91网站| 国产 日韩 欧美 精品| 欧美性xxxx图片| 女厕盗摄一区二区三区| 唐朝av高清盛宴| 精品国产一区三区| 国产精品一区毛片| 日韩欧美在线网站| 国产午夜一区| 国产美女极度色诱视频www| 亚洲欧美卡通动漫| 久久电影一区| 伊人性伊人情综合网| 黄页网站大全在线免费观看| а√天堂8资源在线官网| 国产伦精品一区二区三区视频孕妇| 日韩毛片视频在线看| 国产高清视频一区三区| 91视频这里只有精品| 欧美揉bbbbb揉bbbbb| 殴美一级黄色片| 日韩中文欧美在线| 午夜丝袜av电影| 国产主播性色av福利精品一区| 福利电影一区二区三区| www.av在线视频| 九色视频在线观看免费| 亚洲国产精品久久久久婷婷老年| 亚洲精品videosex极品| 黄页网站在线播放| 国产av不卡一区二区| 欧美亚洲免费在线| 欧美大片1688网站| 欧美性xxxx极品高清hd直播| www成人免费| 精品视频在线免费看| 亚洲一区二区三区爽爽爽爽爽| 九九视频精品在线观看| 欧美伊人亚洲伊人色综合动图| 在线日韩一区二区| 北条麻妃一区二区三区中文字幕| 成人激情视频网| 综合欧美精品| 99精品视频免费观看| 国产人成免费视频| 热久久久久久久| 国产 日韩 欧美 在线| 欧美精品一区二区在线观看| 国产中文字幕在线免费观看| 国产精品123| 大白屁股一区二区视频| 在线观看亚洲专区| 国产一区二区三区天码| 四虎影成人精品a片| 精品人妻一区二区三区浪潮在线| 午夜一区二区三区不卡视频| 久久久人人人| 国产精品999在线观看| 一级特黄aaa大片在线观看| 精品久久久精品| 午夜精品美女自拍福到在线| 国产精品一区二区久久国产| 天堂在线观看免费视频| 91精品国产麻豆国产自产在线| 亚洲一卡二卡区| 伊人久久大香伊蕉在人线观看热v| 谁有免费的黄色网址| 欧美三日本三级少妇三2023| 成人漫画网站免费| 成人免费在线一区二区三区| 亚洲欧美自拍一区| 一本一本久久a久久精品综合妖精| 日本免费在线精品| 黑鬼大战白妞高潮喷白浆| 亚洲图区综合网| 91色精品视频在线| 激情小视频在线观看| 青青草视频网站| 久久999免费视频| 欧美激情精品久久久久久变态| 亚洲午夜福利在线观看| 精品国产1区2区3区| 国产精品8888| 精品国产二区在线| 一区二区亚洲| 天堂在线资源库| 66久久国产| 国产叼嘿视频在线观看| 国产精品高潮呻吟久久av野狼| 深夜成人福利| 一区二区三区免费在线观看| 国产综合视频| 亚洲欧洲一区二区三区在线观看| 国产精品美女久久久久久久网站| 国产日韩欧美a| 日韩精品久久久| 国产精品亚洲成在人线| 国模少妇一区二区三区| 亚洲最大成人网4388xx| 国产一级电影网| 免费看av毛片| 久久久91精品国产一区二区三区| 精品久久久久久最新网址| 丁香视频免费观看| 天天躁日日躁狠狠躁欧美巨大小说| 日韩国产精品久久| 97久久天天综合色天天综合色hd| 久久精品久久久久| 日韩精品免费专区| 中文字幕制服诱惑| 91网站免费看| 电影中文字幕一区二区| 精品美女在线播放| 国产麻豆乱码精品一区二区三区| 手机在线精品视频| 黄色激情视频在线观看| 91久久国产精品| 日本成址在线观看| 国产丰满果冻videossex| 色欲无码人妻久久精品| 99久久国产综合精品五月天喷水| 激情综合色综合啪啪开心| 国产高清视频网站| 九九热线视频只有这里最精品| 色噜噜久久综合| 午夜一区二区三视频在线观看| 天堂网www天堂在线网| 国产网站一区二区三区| 91高清视频在线观看| 成年人网站在线| 91视视频在线直接观看在线看网页在线看| 91免费视频播放| 亚洲欧美日韩国产中文| 国产亚洲成年网址在线观看| 国产主播精品在线| 中文字幕 日韩 欧美| 久久久久在线| www.com黄色片| 99久久一区三区四区免费| 欧美xxxx做受欧美88bbw| 国产一区二区三区黄片| 91免费版在线观看| 91麻豆精品国产91久久久资源速度| 日韩中文字幕网| 91小视频在线免费看| 亚洲成人免费av| 少妇精品久久久一区二区| 欧美极品少妇全裸体| 992tv国产精品成人影院| 夜夜躁很很躁日日躁麻豆| 日韩精品一区国产| 黄页网站一区| 天天躁日日躁狠狠躁av麻豆男男| 在线免费看av| 国产精品186在线观看在线播放| 青娱乐精品视频| 激情久久99| 黄色三级视屏| 最近中文字幕在线观看视频| 日韩成人精品| 你懂的成人av| 日本国产欧美一区二区三区| 日本高清视频www| h网站免费观看| 亚洲视频中文字幕在线观看| 翔田千里在线视频| 国产激情视频网站| 绿色成人影院| 无码人妻久久一区二区三区不卡| 欧美久久一二三四区| 午夜精品一区二区三区av| 日本亚洲视频在线| 国产麻豆精品theporn| 91精品婷婷国产综合久久| 色婷婷综合激情| 麻豆影视在线播放| 97一区二区国产好的精华液| 松下纱荣子在线观看| 人人爱人人爽| www.久久热.com| 乱人伦中文视频在线| 国产伦精品一区二区三区免费迷| 青青青草原在线| 中文成人无字幕乱码精品区| 98精品国产高清在线xxxx天堂| 亚洲免费网站在线观看| 五月婷婷综合久久| 国产精品一区而去| 国产成人av一区| 欧美一二三四在线| 久久韩剧网电视剧| 欧美系列一区| 91精品一区二区三区四区| 男人日女人下面视频| 日本福利视频在线观看| 国产91在线观看丝袜| 成人一道本在线| 日韩欧美国产一二三区| 亚洲精品一区二区| 欧美一区二区免费在线观看| 国产不卡视频在线| av电影天堂一区二区在线| 成人ww免费完整版在线观看| 亚洲v日韩v欧美v综合| 国产欧美黑人| 免费看污污视频| av影片在线播放| 熟女俱乐部一区二区| 美乳中文字幕| 亚洲欧洲高清| 中日韩av电影| 香港伦理在线| 在线观看av中文| 欧美一区二区久久| 久久综合婷婷| www.国产在线视频| 国产一区二区欧美| 日韩欧美一级特黄在线播放| aⅴ在线免费观看| 黄在线观看免费网站ktv| 伊人成年综合电影网| 国内外成人免费激情在线视频网站| 日韩深夜视频| 国产精品白丝一区二区三区| 国产精品一区二区三区成人| 精品网站在线看| 国产激情在线观看视频| 中文字幕超清在线免费观看| 国产高清自产拍av在线| 久久人人超碰精品| 99热精品在线播放| 狠狠色综合久久婷婷| av一区二区三区在线| 欧美性潮喷xxxxx免费视频看| 涩涩网站在线观看| 亚洲天堂视频在线观看免费| 久久久久久久久久久久久女国产乱| 精品国产乱子伦一区| 亚洲女与黑人做爰| 视频黄页在线| 亚洲黄色在线观看视频| 精品国偷自产在线| 亚洲熟女少妇一区二区| 国产丶欧美丶日本不卡视频| 日本电影久久久| 日韩一卡二卡三卡| 欧美婷婷久久五月精品三区| www激情五月| 一区二区三区四区免费视频| 美女扒开内裤让男人桶| 国产精品久久久久久久av福利| 狠狠色2019综合网| 色偷偷亚洲女人天堂观看欧| 九色国产视频| 色黄视频在线观看| 国产精品热视频| 东京干手机福利视频| 国产精品免费麻豆入口| 欧美精品一区二区三区在线四季| 日韩av综合中文字幕| 亚洲免费影视| 欧美精品久久久久久久小说| 波多野结衣亚洲色图| 专区另类欧美日韩| 成人永久免费视频| 在线观看一区二区三区四区| 久久久午夜电影| 成人午夜视频精品一区| 四虎影视最新网站入口在线观看| 嫩草影院在线观看网站成人| 97超碰在线免费| 欧美激情网址| 亚洲免费视频中文字幕| gay欧美网站| 日韩成人av在线播放| 国产日韩精品一区二区| 欲求不满中文字幕| 亚洲精品大片| 久青草国产97香蕉在线视频| 久久综合九色综合久久久精品综合| 欧美成人免费在线视频| 国产精品女主播视频| 国产精品无码在线| 欧美日韩视频免费在线观看| 免费黄色一级大片| 国产社区精品视频| 九九九九九国产| 韩国三级日本三级少妇99| 欧美日韩久久久久| 色婷婷久久久亚洲一区二区三区| 久草视频中文在线| 国产毛片一区二区三区| 亚洲韩国青草视频| 日韩一级视频免费观看在线| 17c丨国产丨精品视频| 中文字幕亚洲二区| 国产调教打屁股xxxx网站| 亚洲人成网站777色婷婷| 国产精品国产馆在线真实露脸| 99国产成+人+综合+亚洲欧美| 一区二区三区四区日本视频| 国产毛片毛片毛片毛片毛片| 久久最新资源网| 美女福利精品视频| 欧美国产精品va在线观看| 欧美成人福利在线观看| 中文字幕在线视频免费观看| 午夜成年人在线免费视频| 唐朝av高清盛宴| 国产主播欧美精品| 亚洲尤物影院|