欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

基于html5中canvas做批改作業(yè)小插件的示例分析-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)基于html5中canvas做批改作業(yè)小插件的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站設計、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設與策劃設計,永靖網(wǎng)站建設哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設十余年,網(wǎng)設計領(lǐng)域的專業(yè)建站公司;建站業(yè)務涵蓋:永靖等地區(qū)。永靖做網(wǎng)站價格咨詢:18982081108

需求分析


  1. 能進行批改,就是相當于畫筆

  2. 能進行畫筆的撤回功能

  3. 能進行全部畫筆的清除功能

  4. 可以轉(zhuǎn)化畫筆的顏色

技術(shù)上的實現(xiàn)思路


在聽到這需求后的第一反應就是用canvas來做,所以我在w3school閱讀了 canvas的API .

1.將圖片轉(zhuǎn)到canvas,用到API: drawImage()

2畫筆的實現(xiàn)

  • 當按下鼠標(mousedown)記錄開始點startX, startY

  • 當移動鼠標的時候(mousemove)就獲取當前的鼠標的坐標e.clientX, e.clientY,獲取到了當前的坐標后,與上一個點的坐標軸的左邊進行連線(lineTo ),這樣就能畫出了一條橫線了

  • 當鼠標松開左鍵(mouseup)時候,就清除mousemove的函數(shù)

3.清除功能:講原始的圖片再次用drawImage()函數(shù)來重置
4.撤回功能:在每次按下鼠標那時候,用getImageData()函數(shù)獲取當前的圖像記錄到數(shù)組里面,然后按撤回則使用putImageData()函數(shù)放在canvas
5.畫筆的顏色:在mousemove里面改變strokeStyle筆的顏色

代碼實現(xiàn)


移動鼠標畫出線條的代碼

let self = this;
    this.canvasNode = document.createElement('canvas');
    let styleString = this.utils.formatStyle(CANVAS_STYLE); // CANVAS_STYLE是canvas的樣式
    this.canvasNode.setAttribute('id','canvas');
    // 一定要設置這width 和 height
    let ratio = this.imgNode.width / this.imgNode.height, height = this.imgNode.height, width = this.imgNode.width;
    let tempWidth , tempHeight;
    // 按比例伸縮
    if(ratio >= window.innerWidth / window.innerHeight){
      if(width > window.innerWidth){
        tempWidth = window.innerWidth;
        tempHeight = height * window.innerWidth / width;
      } else {
        tempWidth = width;
        tempHeight = height;
      }
    }else{
      if(height > window.innerHeight){
        tempWidth = width * window.innerHeight / width;
        tempHeight = window.innerHeight;
      }else{
        tempWidth = width;
        tempHeight = height;
      }
    }
    this.canvasNode.height = tempHeight;
    this.canvasNode.width = tempWidth;
    styleString = Object.assign({'width': tempWidth, 'height': tempHeight}, CANVAS_STYLE);
    this.canvasNode.setAttribute('style', styleString);

    let ctx = this.canvasNode.getContext('2d'), startX = 0, startY = 0;
    let image = new Image() ;
    image.setAttribute("crossOrigin",'Anonymous')
    // 加時間戳因為這圖片的域名沒設置跨域/tupian/20230522/upgrade
    image.src = this.imgNode.src + '?t=' + new Date().getTime(); 
    image.height = tempHeight;
    image.width = tempWidth;
    image.onload = function(){
      ctx.drawImage(image, 0, 0, tempWidth, tempHeight);
    }
    // 鼠標移動事件
    let mousemoveFn = function(e) {
      ctx.beginPath();
      ctx.lineWidth = 3;
      ctx.strokeStyle = self.currentColor;
      if(startX == e.clientX - self.canvasNode.offsetLeft || startY ===  e.clientY - self.canvasNode.offsetTop  ) return
      ctx.moveTo(startX,startY);
      ctx.lineTo(e.clientX - self.canvasNode.offsetLeft , e.clientY - self.canvasNode.offsetTop );
      ctx.stroke();
      startX = e.clientX - self.canvasNode.offsetLeft;
      startY = e.clientY - self.canvasNode.offsetTop ; // 37是header的高度
    }
    // 鼠標按下事件
    this.canvasNode.addEventListener("mousedown",function(e){
      startX = e.clientX - self.canvasNode.offsetLeft;
      startY = e.clientY - self.canvasNode.offsetTop ;

      // 如果在mouseup那里記錄 則在撤回時候要做多一個步驟
      let imageData = ctx.getImageData(0,0, self.canvasNode.width, self.canvasNode.height);
      self.imageDataArray.push(imageData); // 這imageDataArray用來記錄畫筆的筆畫
      self.canvasNode.addEventListener("mousemove", mousemoveFn, false);
    },false);
    this.canvasNode.addEventListener('mouseup', function(e){
      self.canvasNode.removeEventListener('mousemove', mousemoveFn);
    });
    this.bgNode.appendChild(this.canvasNode);

遇到的問題

1.圖片的跨域問題   因為這個域名只設置了192.168.6.*的跨域,所以我localhost的域名會報跨域的問題(只對192.168.6.*的跨域是同事告訴我的,不然我還在傻乎乎的查問題)

解決辦法:設置vue.congfig.js文件的dev下的host

2.圖片的按比例伸縮完按保存后圖片的尺寸變了   我用toDataURL()方法輸出的base64后的圖片尺寸變了。原因:在我把圖片draw上canvas上時候,用了上面代碼的圖片那比例伸縮的算法把圖片變小了,所以畫在canvas上的圖片也變小了...

解決辦法:(待解決)

總結(jié)


  • 第一次接觸canvas與圖片相結(jié)合的功能,讓我熟悉了canvas的api

  • 在遇到?jīng)]做過的功能之前,一定要先定下心來運用你所知道的知識思考下有沒可行的方法,找到了突破點就可以做了

  • 在你碰上不熟悉的知識時候,一定要先看api,我這canvas之前不怎么會的,之后我細看了幾遍的api,我就可以上手去做功能了,并且在w3school看到的例子讓我覺得canvas真的很強大

感謝各位的閱讀!關(guān)于“基于html5中canvas做批改作業(yè)小插件的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

網(wǎng)站欄目:基于html5中canvas做批改作業(yè)小插件的示例分析-創(chuàng)新互聯(lián)
轉(zhuǎn)載源于:http://chinadenli.net/article40/jgcho.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供電子商務、網(wǎng)站策劃營銷型網(wǎng)站建設、云服務器、小程序開發(fā)、移動網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設
欧美不卡高清一区二区三区| 亚洲性日韩精品一区二区| 国产成人精品一区二区在线看| 高跟丝袜av在线一区二区三区| 五月天婷亚洲天婷综合网| 久久天堂夜夜一本婷婷| 日韩人妻免费视频一专区| 国产水滴盗摄一区二区| 蜜臀人妻一区二区三区| 国产一区二区熟女精品免费| 国产三级不卡在线观看视频| 久久精品少妇内射毛片| 亚洲一区二区福利在线| 欧美成人免费一级特黄| 国产一区二区精品丝袜| 狠狠亚洲丁香综合久久| 九九九热在线免费视频| 国产又色又爽又黄的精品视频| 亚洲熟妇中文字幕五十路| 激情内射日本一区二区三区| 亚洲欧美日本成人在线| 午夜国产精品国自产拍av| 东京热加勒比一区二区| 国产一二三区不卡视频| 丝袜视频日本成人午夜视频| 国语对白刺激高潮在线视频| 亚洲一区二区三区四区| 色小姐干香蕉在线综合网| 久久99夜色精品噜噜亚洲av| 黑人巨大精品欧美一区二区区 | 精品国产av一区二区三区不卡蜜| 午夜久久久精品国产精品| 国产肥女老熟女激情视频一区| 国产91色综合久久高清| 欧美成人精品国产成人综合 | 麻豆欧美精品国产综合久久| 日本成人三级在线播放| 超薄丝袜足一区二区三区| 91久久精品国产成人| 中文字幕日韩欧美一区| 国产视频在线一区二区|