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

Vue和uniapp中該如何使用canvas詳解

 更新時(shí)間:2022年10月25日 09:49:22   作者:無(wú)·糖  
說(shuō)起canvas是css3新增的標(biāo)簽,而餅狀圖又是canvas經(jīng)典,我們公司現(xiàn)在正在用uni-app框架去研發(fā)APP,下面這篇文章主要給大家介紹了關(guān)于Vue和uniapp中該如何使用canvas的相關(guān)資料,需要的朋友可以參考下

Vue與uniapp中如何使用canvas?

一般Vue情況下我們使用canvas是這樣使用的

//創(chuàng)建canvas元素
<canvas
      id="output_mini"
      width="1400"
      height="790"
      style="display: block;position: absolute;top:0;"
      />
      
//找到canvas元素
const canvas = document.getElementById("output_mini");
      
//創(chuàng)建context對(duì)象
this.context = canvas.getContext("2d");

//然后畫線段畫圓等操作
ctx.moveTo(0,0);  //定義開(kāi)始坐標(biāo)(0,0)
ctx.lineTo(200,100); //結(jié)束坐標(biāo) (200,100)
ctx.stroke(); // stroke() 方法來(lái)繪制線條:

但是在uniapp中,不能像上面這樣直接創(chuàng)建context對(duì)象。需要通過(guò)uniapp官方提供的方法來(lái)創(chuàng)建context對(duì)象,之后在進(jìn)行其他的操作。

示例

//創(chuàng)建canvas元素
<canvas canvas-id="output_mini" width="400" height="360" style="display: block;position: absolute;top:0;" 

//創(chuàng)建context對(duì)象
var ctx = uni.createCanvasContext('output_mini', this);

屬性說(shuō)明

屬性名類型說(shuō)明
typeString指定 canvas 類型,支持 2d (2.9.0) 和 webgl
canvas-idStringcanvas 組件的唯一標(biāo)識(shí)符
disable-scrollBoolean當(dāng)在 canvas 中移動(dòng)時(shí)且有綁定手勢(shì)事件時(shí),禁止屏幕滾動(dòng)以及下拉刷新
hidpiBoolean是否啟用高清處理
@touchstartEventHandle手指觸摸動(dòng)作開(kāi)始
@touchmoveEventHandle手指觸摸后移動(dòng)
@touchendEventHandle手指觸摸動(dòng)作結(jié)束
@touchcancelEventHandle手指觸摸動(dòng)作被打斷,如來(lái)電提醒,彈窗
@longtapEventHandle手指長(zhǎng)按 500ms 之后觸發(fā),觸發(fā)了長(zhǎng)按事件后進(jìn)行移動(dòng)不會(huì)觸發(fā)屏幕的滾動(dòng)
@errorEventHandle當(dāng)發(fā)生錯(cuò)誤時(shí)觸發(fā) error 事件,detail = {errMsg: ‘something wrong’}

注意事項(xiàng):

  • canvas 標(biāo)簽?zāi)J(rèn)寬度 300px、高度 225px,動(dòng)態(tài)修改 canvas 大小后需要重新繪制。
  • h5、app-vue 中單個(gè)尺寸過(guò)大的 canvas 在 iOS/Safari 無(wú)法繪制(具體限制尺寸未公布)。
  • 同一頁(yè)面中的 canvas-id 不可重復(fù),如果使用一個(gè)已經(jīng)出現(xiàn)過(guò)的 canvas-id,該 canvas標(biāo)簽對(duì)應(yīng)的畫布將被隱藏并不再正常工作。
  • canvas 在微信小程序、百度小程序、QQ小程序中為原生組件,層級(jí)高于前端組件,請(qǐng)勿內(nèi)嵌在scroll-view、swiper、picker-view、movable-view 中使用。解決 canvas 層級(jí)過(guò)高無(wú)法覆蓋,參考native-component。其他小程序端的 canvas 仍然為 webview 中的 canvas。
  • app-vue 中的 canvas 仍然是 webview 的canvas。app-nvue下如需使用canvas,需下載插件。
  • app-vue的canvas雖然是webview自帶的canvas,但卻比nvue和微信小程序的原生canvas性能更高。注意并非原生=更快。canvas動(dòng)畫的流暢,關(guān)鍵不在于渲染引擎的速度,而在于減少?gòu)倪壿媽酉蛞晥D層頻繁通信造成的折損。
  • 小程序、app-nvue,因?yàn)橥ㄐ抛枞?,難以繪制非常流暢的canvas動(dòng)畫。h5和app-vue不存在此問(wèn)題。但注意,app-vue下若想流暢的繪制canvas動(dòng)畫,需要使用renderjs技術(shù),把操作canvas的js邏輯放到視圖層運(yùn)行,避免邏輯層和視圖層頻繁通信。hello uni-app的canvas示例很典型,在相同手機(jī)運(yùn)行該示例,可以看出在h5端和app端非常流暢,而小程序端由于沒(méi)有renderjs技術(shù),做不到這么流暢的動(dòng)畫。

總結(jié)

到此這篇關(guān)于Vue和uniapp中該如何使用canvas的文章就介紹到這了,更多相關(guān)Vue uniapp使用canvas內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論