婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

清空canvas畫布內容

1、重置寬或高

由于canvas每當高度或寬度被重設時,畫布內容就會被清空,因此可以用以下方法清空:(此方法僅限需要清除全部內容的情況)

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()函數,這個函數是用來在畫布上組合顏色,我們可以利用這個原理,疊加(數學上的"或"原理)來制作橡皮。

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

描述
source-over 默認。在目標圖像上顯示源圖像。
source-atop 在目標圖像頂部顯示源圖像。源圖像位于目標圖像之外的部分是不可見的。
source-in 在目標圖像中顯示源圖像。只有目標圖像內的源圖像部分會顯示,目標圖像是透明的。
source-out 在目標圖像之外顯示源圖像。只會顯示目標圖像之外源圖像部分,目標圖像是透明的。
destination-over 在源圖像上方顯示目標圖像。
destination-atop 在源圖像頂部顯示目標圖像。源圖像之外的目標圖像部分不會被顯示。
destination-in 在源圖像中顯示目標圖像。只有源圖像內的目標圖像部分會被顯示,源圖像是透明的。
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現有的像素點的圖像。

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

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

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

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

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

1. 線條存儲及繪制

項目中我存儲的線條hash結構的對象如下:

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

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

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';//轉折的時候不出現尖角
                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); //二次貝塞曲線函數
                    }
                    // 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上的時候將lineWidth擴大加上了eraserRadius(圓形橡皮擦半徑),下圖即為繪制到hitCanvas上的colorKey顏色線條,每個線條顏色值是上圖中的key值colorKey。另外線條粗細明顯比上面的白色線條要粗很多,因為橡皮擦是個cur鼠標樣式它的半徑很大,但獲取的鼠標點擊位置還只是一個像素點坐標,所以為了擴大鼠標點到線條上的范圍將其變粗。

 2. 線擦除和點擦除

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

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

         if (that.isErasePoint) {
                      line.points.foreach(function (i, p) {
                          //橡皮擦距離該線條上點的距離是否在橡皮擦半徑范圍內
                          if (Math.pow(p.x - point.x, 2) + Math.pow(p.y - point.y, 2) <= Math.pow(eraserRadius, 2)) {
                              isSeparate = true;
			      //已經找到橡皮擦半徑范圍內的點,該點不存入兩個集合中的任何一個
                          } else {
                              if (isSeparate)
			      //找到后將之后的點存入另一個點集合points中
                                  points2.add(p);
                           else//找到之前將點存入點集合points1中
                                 points.add(p);
                         }
                     })
                     //遍歷完線條points上的所有點后。根據points1和points2是否為空處理點擦除后的線條
                    if (points1.length() >= 1 && points2.length() >= 1) {
		    //points1和points2都不為空,說明從中間擦除變為兩條線
                         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);
               }

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

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

巨人網絡通訊聲明:本文標題《清除canvas畫布內容(點擦除+線擦除)》,本文關鍵詞  清除,canvas,畫布,內容,點,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《清除canvas畫布內容(點擦除+線擦除)》相關的同類信息!
  • 本頁收集關于清除canvas畫布內容(點擦除+線擦除)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线观看91av| 亚洲欧美综合色| 午夜视频在线观看一区二区三区| 在线观看三级视频欧美| 亚洲一区在线视频观看| 日韩一级完整毛片| 丁香六月综合激情| 亚洲精品国产一区二区精华液| 欧美日韩精品一区视频| 国产一区二区三区日韩| 亚洲精品中文字幕乱码三区| 日韩美女天天操| 91丨porny丨户外露出| 亚洲 欧美综合在线网络| 久久蜜桃香蕉精品一区二区三区| 99re亚洲国产精品| 男男gaygay亚洲| 亚洲三级电影网站| 欧美大尺度电影在线| 在线一区二区三区做爰视频网站| 久久97超碰色| 一区二区国产盗摄色噜噜| 欧美老人xxxx18| 成人av在线网| 国产一区二区美女诱惑| 亚洲精品国产一区二区精华液| 日韩欧美国产wwwww| 色综合久久中文字幕综合网 | 国产河南妇女毛片精品久久久| 亚洲日本中文字幕区| 久久影院午夜片一区| 欧美久久一区二区| 99久久精品费精品国产一区二区| 激情深爱一区二区| 日韩成人精品在线| 亚洲成人av中文| 亚洲乱码国产乱码精品精98午夜| 中文字幕乱码日本亚洲一区二区 | 欧美一级高清片| 欧美天堂一区二区三区| 成人高清视频在线| 国产99久久久国产精品免费看 | 亚洲欧洲无码一区二区三区| 久久久综合激的五月天| 欧美成人官网二区| 欧美一级爆毛片| 日韩欧美国产小视频| 欧美综合在线视频| 色天使色偷偷av一区二区| 成人激情图片网| 不卡电影一区二区三区| 久久99最新地址| 狠狠色伊人亚洲综合成人| 美女看a上一区| 亚瑟在线精品视频| 午夜久久久久久久久久一区二区| 国产精品色噜噜| 久久久精品黄色| 337p亚洲精品色噜噜狠狠| 这里只有精品视频在线观看| 欧美区视频在线观看| 91精品国模一区二区三区| 日韩三级视频中文字幕| 2023国产精华国产精品| 久久精品人人做人人爽人人| 久久精品视频网| 最新久久zyz资源站| 亚洲精品日日夜夜| 天天色天天爱天天射综合| 青青草原综合久久大伊人精品 | 成人欧美一区二区三区黑人麻豆 | 国产校园另类小说区| 久久久www成人免费无遮挡大片| 欧美久久一二区| 久久综合精品国产一区二区三区| 久久久精品一品道一区| 亚洲色欲色欲www| 琪琪一区二区三区| 成人综合在线视频| 欧美美女直播网站| 精品免费一区二区三区| 国产精品乱人伦中文| 亚洲无人区一区| 精品一区二区日韩| 色综合色狠狠天天综合色| 91精品国产综合久久福利| 中文字幕高清不卡| 日韩不卡一二三区| 91网站在线播放| 欧美日韩久久一区二区| 精品福利在线导航| 一区二区三区日本| 国产一区二区不卡老阿姨| www.日韩在线| 欧美日韩另类一区| 国产精品视频你懂的| 伦理电影国产精品| 在线一区二区三区做爰视频网站| 欧美午夜精品免费| 欧美日韩精品欧美日韩精品| 国产网红主播福利一区二区| 亚洲第一在线综合网站| 国产精品一区二区久久不卡 | 亚洲福中文字幕伊人影院| 国产剧情av麻豆香蕉精品| 欧美吻胸吃奶大尺度电影| 中文无字幕一区二区三区| 免费成人在线观看| 在线视频你懂得一区| 国产精品大尺度| 国产ts人妖一区二区| 91福利小视频| 91精品国产综合久久香蕉麻豆| 中文字幕亚洲在| 国产成人自拍网| 欧美成人艳星乳罩| 午夜精品爽啪视频| 欧美中文字幕一区二区三区亚洲| 国产精品久久久久久久久动漫 | 亚洲女同女同女同女同女同69| 国产剧情一区二区| xnxx国产精品| 国产一区二区福利视频| 久久综合九色欧美综合狠狠| 久国产精品韩国三级视频| 日韩欧美一卡二卡| 偷窥少妇高潮呻吟av久久免费| 欧美综合色免费| 亚洲午夜精品网| 欧美日韩国产精品成人| 亚洲一区二三区| 欧美日韩国产一区| 首页亚洲欧美制服丝腿| 99这里都是精品| 亚洲欧洲成人精品av97| 国产一区二区福利视频| 精品视频一区 二区 三区| 一区二区日韩av| 欧美日韩国产一级| 蜜乳av一区二区三区| 精品成人a区在线观看| 国产精品亚洲а∨天堂免在线| 久久久久国产精品麻豆ai换脸| 国产精品996| 国产精品二三区| 在线亚洲欧美专区二区| 亚洲综合色自拍一区| 91精品蜜臀在线一区尤物| 黄色精品一二区| 国产精品色哟哟网站| 91麻豆自制传媒国产之光| 亚洲大片精品永久免费| 日韩欧美一二三| 99久久亚洲一区二区三区青草| 亚洲综合一区二区| 日韩午夜三级在线| 视频一区二区三区在线| 欧美久久久久久久久久| 国产乱色国产精品免费视频| 亚洲色图第一区| 制服视频三区第一页精品| 岛国精品在线播放| 视频一区欧美精品| 国产精品久久久一区麻豆最新章节| 日本高清不卡aⅴ免费网站| 麻豆免费看一区二区三区| 国产精品久久久久永久免费观看| 成人免费高清视频在线观看| 亚洲色图色小说| 欧美性受xxxx| 国产福利精品一区二区| 亚洲图片一区二区| 国产精品视频观看| 日韩一级完整毛片| 91丨九色丨黑人外教| 久久爱另类一区二区小说| 免费成人性网站| 麻豆精品国产传媒mv男同 | 欧美久久免费观看| 4438亚洲最大| 日韩一级完整毛片| 精品久久国产老人久久综合| 日韩美女视频在线| 久久亚洲捆绑美女| 国产精品天干天干在观线| 国产精品久久精品日日| 中文字幕一区二区三中文字幕| 亚洲欧美一区二区在线观看| 亚洲精品网站在线观看| 亚洲成在线观看| 久久精品国产99| 国产成人精品免费网站| caoporm超碰国产精品| 91啦中文在线观看| 欧美日韩一级二级三级| 日韩色在线观看| 亚洲国产成人在线| 亚洲免费观看高清在线观看| 天天色综合成人网| 国产高清不卡一区二区|