欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

uniapp中canvas繪制圖片內(nèi)容空白報(bào)錯(cuò)的原因及解決

 更新時(shí)間:2023年09月17日 10:26:05   作者:癡心阿文  
最近有個(gè)需求就是要用canvas畫個(gè)分享的海報(bào),所以這里總結(jié)下,這篇文章主要給大家介紹了關(guān)于uniapp中canvas繪制圖片內(nèi)容空白報(bào)錯(cuò)的原因及解決方法,需要的朋友可以參考下

問題圖: 

效果圖:

Canvas繪制圖片流程

簡(jiǎn)單說一下canvas上繪制圖片的過程

??先調(diào)用相機(jī)接口拍攝照片,

??把照片URL拿到,

??然后獲取照片URL信息寬高,

??把寬高給畫布,??使用canvas的drawImage API把圖片繪制到canvas上,??繪制方法執(zhí)行完成后把這個(gè)canvas導(dǎo)出為圖片,并上傳到服務(wù)器,至此流程結(jié)束。

首先定義畫布canvas

<canvas class="canvas" canvas-id="canvas"
				:style="{ height: canvasHeight + 'px', width: canvasWidth + 'px'  }"></canvas>

1.畫布的大小大于了圖片的大小導(dǎo)致了生成的內(nèi)容是空白的

canvas畫布初始值沒有,導(dǎo)致沒有繪制成功

解決:

 //默認(rèn)初始值   canvasWidth1  canvasHeight1
data() {
        return {
			ctx: null,
			canvasWidth: 1080,
			canvasHeight: 1440,
        }
    },

2.繪制圖片沒有放到wx.draw方法里面

wx.draw(false, () =>{
  wx.canvasToTempFilePath({
       x: 0,
       y: 0,
       canvasId: 'shareCanvas',  // shareCanvas 為制定 繪圖canvas 的ID
       success: (res) => {
            this.storeImgPath = res.tempFilePath
            ....寫入生成完成的邏輯
       },
      complete: (res) => {
           wx.hideLoading()
       }
  })
})

3.Failed to execute ‘toDataURL’ on ‘HTMLCanvasElement’: Tainted canvases may not be exported.

報(bào)錯(cuò)信息

 canvas無(wú)法執(zhí)行toDataURL方法,受污染的畫布無(wú)法輸出

 受限于CORS 策略,會(huì)存在跨域問題,頁(yè)面雖然可以使用跨域的圖片(比如使用img標(biāo)簽或者append到頁(yè)面上),因?yàn)闉g覽器本身不會(huì)有跨域問題,但是一旦繪制到canvas上就會(huì)污染這個(gè)canvas,導(dǎo)致無(wú)法提取到這個(gè)canvas的數(shù)據(jù),也就無(wú)法輸出了。

上面的都加了還存在,必殺技,延遲方法:

//萬(wàn)能代碼,不能用你回來(lái)找我,能用可以雙擊點(diǎn)贊評(píng)論666	
console.log('正在繪制')
			this.ctx.draw(false,(()=> {
				setTimeout(() => {
				uni.canvasToTempFilePath({
					x: 0,
					y: 0,
					width: this.canvasWidth1,
					height: this.canvasHeight1,
					destWidth: this.canvasWidth1,
					destHeight: this.canvasHeight1,
					canvasId: 'myCanvas',quality:0.6,
					success: res => {
						// 在H5平臺(tái)下,tempFilePath 為 base64
						console.log(res,'繪制完成===',)
						//上傳
						uni.uploadFile({
							url: url, //僅為示例,非真實(shí)的接口地址
							filePath:res.tempFilePath,
							header: {
								'token': self.$store.state.token,"version":"100.0.00"
							},
							name: 'file',
							formData: {},
							success: (uploadFileRes) => {
								console.log('uploadFileRes===1111',uploadFileRes)
								uni.hideLoading()
							},
							fail(err) {
								console.log(err)
								uni.hideLoading()
							}
						});
					//	this.pictureArr.push(res.tempFilePath);
					},
					fail(err) {
						console.log(err)
						uni.showToast({
							title:'上傳圖片失敗!',icon:'none',
							duration: 3000
						})
						uni.hideLoading()
					}
				}, this)
				}, 3500)
			})());

萬(wàn)能代碼,不能用你回來(lái)找我

總結(jié)

到此這篇關(guān)于uniapp中canvas繪制圖片內(nèi)容空白報(bào)錯(cuò)的原因及解決的文章就介紹到這了,更多相關(guān)uniapp canvas繪制圖片內(nèi)容空白內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 自定義require函數(shù)讓瀏覽器按需加載Js文件

    自定義require函數(shù)讓瀏覽器按需加載Js文件

    可能很多人看到這個(gè)題目就會(huì)想到LABjs、RequireJS、SeaJS... 這些庫(kù),但無(wú)奈小編沒用過這些庫(kù),什么 AMD 、CMD 哪來(lái)那么多術(shù)語(yǔ)... 前端的庫(kù)太多了,要看各種亂七八糟的文檔,好難啊,還不如自己寫一個(gè)庫(kù)呢。于是就有了這文章,有需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2016-11-11
  • js實(shí)現(xiàn)彈框效果

    js實(shí)現(xiàn)彈框效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)彈框效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • Ajax高級(jí)筆記 JavaScript高級(jí)程序設(shè)計(jì)筆記

    Ajax高級(jí)筆記 JavaScript高級(jí)程序設(shè)計(jì)筆記

    這篇文章主要介紹了Ajax高級(jí)筆記 JavaScript高級(jí)程序設(shè)計(jì)筆記,需要的朋友可以參考下
    2017-06-06
  • 非主流的textarea自增長(zhǎng)實(shí)現(xiàn)js代碼

    非主流的textarea自增長(zhǎng)實(shí)現(xiàn)js代碼

    今天稍微研究了下textarea隨輸入內(nèi)容自動(dòng)增長(zhǎng)的功能,通過google參考了一些實(shí)現(xiàn)方式
    2011-12-12
  • Bootstrap CSS組件之導(dǎo)航(nav)

    Bootstrap CSS組件之導(dǎo)航(nav)

    這篇文章主要為大家詳細(xì)介紹了Bootstrap CSS組件之導(dǎo)航(nav),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • js實(shí)現(xiàn)瀑布流的三種方式比較

    js實(shí)現(xiàn)瀑布流的三種方式比較

    瀑布流,又稱瀑布流式布局,是比較流行的一種網(wǎng)站頁(yè)面布局,這篇文章主要介紹了js實(shí)現(xiàn)瀑布流的三種方式,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript的六種繼承方式(推薦)

    JavaScript的六種繼承方式(推薦)

    繼承是面向?qū)ο缶幊讨杏忠环浅V匾母拍睿琂avaScript支持實(shí)現(xiàn)繼承,不支持接口繼承,實(shí)現(xiàn)繼承主要依靠原型鏈來(lái)實(shí)現(xiàn)的
    2017-06-06
  • JS前后端實(shí)現(xiàn)身份證號(hào)驗(yàn)證代碼解析

    JS前后端實(shí)現(xiàn)身份證號(hào)驗(yàn)證代碼解析

    這篇文章主要介紹了JS前后端實(shí)現(xiàn)身份證號(hào)驗(yàn)證代碼解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • 菜單制作學(xué)習(xí)一個(gè)小東西

    菜單制作學(xué)習(xí)一個(gè)小東西

    菜單制作學(xué)習(xí)一個(gè)小東西...
    2006-09-09
  • TypeScript裝飾器與反射元數(shù)據(jù)實(shí)例詳解

    TypeScript裝飾器與反射元數(shù)據(jù)實(shí)例詳解

    TypeScript的裝飾器為我們提供了一種強(qiáng)大的工具,可以在運(yùn)行時(shí)改變類的行為,通過理解裝飾器的工作原理,我們可以創(chuàng)造更加強(qiáng)大、靈活且易于維護(hù)的應(yīng)用,這篇文章主要介紹了TypeScript裝飾器與反射元數(shù)據(jù),需要的朋友可以參考下
    2023-09-09

最新評(píng)論