Vue和uniapp中該如何使用canvas詳解
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對象
this.context = canvas.getContext("2d");
//然后畫線段畫圓等操作
ctx.moveTo(0,0); //定義開始坐標(0,0)
ctx.lineTo(200,100); //結束坐標 (200,100)
ctx.stroke(); // stroke() 方法來繪制線條:
但是在uniapp中,不能像上面這樣直接創(chuàng)建context對象。需要通過uniapp官方提供的方法來創(chuàng)建context對象,之后在進行其他的操作。
示例
//創(chuàng)建canvas元素
<canvas canvas-id="output_mini" width="400" height="360" style="display: block;position: absolute;top:0;"
//創(chuàng)建context對象
var ctx = uni.createCanvasContext('output_mini', this);
屬性說明
| 屬性名 | 類型 | 說明 |
|---|---|---|
| type | String | 指定 canvas 類型,支持 2d (2.9.0) 和 webgl |
| canvas-id | String | canvas 組件的唯一標識符 |
| disable-scroll | Boolean | 當在 canvas 中移動時且有綁定手勢事件時,禁止屏幕滾動以及下拉刷新 |
| hidpi | Boolean | 是否啟用高清處理 |
| @touchstart | EventHandle | 手指觸摸動作開始 |
| @touchmove | EventHandle | 手指觸摸后移動 |
| @touchend | EventHandle | 手指觸摸動作結束 |
| @touchcancel | EventHandle | 手指觸摸動作被打斷,如來電提醒,彈窗 |
| @longtap | EventHandle | 手指長按 500ms 之后觸發(fā),觸發(fā)了長按事件后進行移動不會觸發(fā)屏幕的滾動 |
| @error | EventHandle | 當發(fā)生錯誤時觸發(fā) error 事件,detail = {errMsg: ‘something wrong’} |
注意事項:
- canvas 標簽默認寬度 300px、高度 225px,動態(tài)修改 canvas 大小后需要重新繪制。
- h5、app-vue 中單個尺寸過大的 canvas 在 iOS/Safari 無法繪制(具體限制尺寸未公布)。
- 同一頁面中的 canvas-id 不可重復,如果使用一個已經(jīng)出現(xiàn)過的 canvas-id,該 canvas標簽對應的畫布將被隱藏并不再正常工作。
- canvas 在微信小程序、百度小程序、QQ小程序中為原生組件,層級高于前端組件,請勿內(nèi)嵌在scroll-view、swiper、picker-view、movable-view 中使用。解決 canvas 層級過高無法覆蓋,參考native-component。其他小程序端的 canvas 仍然為 webview 中的 canvas。
- app-vue 中的 canvas 仍然是 webview 的canvas。app-nvue下如需使用canvas,需下載插件。
- app-vue的canvas雖然是webview自帶的canvas,但卻比nvue和微信小程序的原生canvas性能更高。注意并非原生=更快。canvas動畫的流暢,關鍵不在于渲染引擎的速度,而在于減少從邏輯層向視圖層頻繁通信造成的折損。
- 小程序、app-nvue,因為通信阻塞,難以繪制非常流暢的canvas動畫。h5和app-vue不存在此問題。但注意,app-vue下若想流暢的繪制canvas動畫,需要使用renderjs技術,把操作canvas的js邏輯放到視圖層運行,避免邏輯層和視圖層頻繁通信。hello uni-app的canvas示例很典型,在相同手機運行該示例,可以看出在h5端和app端非常流暢,而小程序端由于沒有renderjs技術,做不到這么流暢的動畫。
總結
到此這篇關于Vue和uniapp中該如何使用canvas的文章就介紹到這了,更多相關Vue uniapp使用canvas內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
antd Form組件方法getFieldsValue獲取自定義組件的值操作
這篇文章主要介紹了antd Form組件方法getFieldsValue獲取自定義組件的值操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
Vue通過for循環(huán)隨機生成不同的顏色或隨機數(shù)的實例
今天小編就為大家分享一篇Vue通過for循環(huán)隨機生成不同的顏色或隨機數(shù)的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
vue3項目如何配置按需自動導入API組件unplugin-auto-import
這篇文章主要介紹了vue3項目如何配置按需自動導入API組件unplugin-auto-import問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
vue.js出現(xiàn)Vue.js?not?detected錯誤的解決方案
這篇文章主要介紹了vue.js出現(xiàn)Vue.js?not?detected錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
Vue 父子組件實現(xiàn)數(shù)據(jù)雙向綁定效果的兩種方式(案例代碼)
本文給大家分享Vue 父子組件實現(xiàn)數(shù)據(jù)雙向綁定效果的兩種方式,方式一是通過監(jiān)聽事件實現(xiàn)方式二是通過 v-model 實現(xiàn),每種方式結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2022-11-11
解決Vue2.0 watch對象屬性變化監(jiān)聽不到的問題
今天小編就為大家分享一篇解決Vue2.0 watch對象屬性變化監(jiān)聽不到的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09

