canvas.md 4.2 KB
Newer Older
D
DCloud_LXH 已提交
1 2 3 4
## canvas

<!-- UTSCOMJSON.canvas.description -->

D
DCloud_LXH 已提交
5 6
<!-- UTSCOMJSON.canvas.compatibility -->

W
wanganxp 已提交
7 8
App平台4.25之前没有完整的canvas组件,但提供了`drawablecontext`
* 每个view,都可以通过[draw API](../dom/drawablecontext.md),高性能的画各种形状、写字。这组API与web的canvas api接近但不同。
9
* 截图或海报需求,无需像webview那样通过canvas中转,app平台view直接提供截图API,[takesnapshot](../dom/unielement.html#takesnapshot)
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
10 11 12
* 二维码展示需求:[见插件市场](https://ext.dcloud.net.cn/search?q=%E4%BA%8C%E7%BB%B4%E7%A0%81&uni-appx=1)
* 图表需求:[插件市场搜echart](https://ext.dcloud.net.cn/search?q=chart&orderBy=Relevance&uni-appx=1)[插件市场搜F2](https://ext.dcloud.net.cn/search?q=f2&orderBy=Relevance&uni-appx=1)
* 手写签名:[见插件市场](https://ext.dcloud.net.cn/search?q=%E7%AD%BE%E5%90%8D&orderBy=Relevance&uni-appx=1)
W
wanganxp 已提交
13 14 15 16 17 18 19 20 21 22 23
* 使用web-view中的canvas也是一种方案,uvue页面里的web-view组件可以和uvue页面里的uts代码双向通信。

从4.25起,App平台也补充了canvas组件。

canvas组件和drawablecontext的区别是:
1. canvas组件的语法是W3C标准语法
2. canvas组件全平台支持,而drawablecontext仅app支持
3. canvas组件是一个独立组件,而drawablecontext是对现有的view组件进行绘制
4. drawablecontext在iOS上绘制文字的性能不佳,其原生系统如此
5. 对于复杂绘制场景,比如游戏,canvas组件的性能优于drawablecontext
6. canvas是一个独立模块,占用几百K体积,不使用时会被摇树摇掉
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
24

25
<!-- UTSCOMJSON.canvas.attribute -->
D
DCloud_LXH 已提交
26 27 28

<!-- UTSCOMJSON.canvas.event -->

29 30
<!-- UTSCOMJSON.canvas.component_type-->

D
DCloud_LXH 已提交
31 32
<!-- UTSCOMJSON.canvas.children -->

W
wanganxp 已提交
33
## API
34

W
wanganxp 已提交
35
老版 uni-app 的 canvas 使用了微信小程序的的旧版规范,和 W3C 规范有差异。微信小程序新版的 canvas 规范已经与 W3C 规范拉齐。
36

W
wanganxp 已提交
37
uni-app x 中废弃了老版方案,使用了 W3C 规范和微信小程序的新版规范。
38

W
wanganxp 已提交
39
注意:在uni-app x 4.21版以前,Web平台开发者写的老版canvas是可以运行的。但从 4.21+ 支持新版规范起,不再支持老版规范。开发者需调整代码。
40

W
wanganxp 已提交
41
注意:新版规范需要开发者根据自己的场景手动处理高清屏问题。
H
hdx 已提交
42

W
wanganxp 已提交
43
canvas相关的API非常多,参考如下:
44

W
wanganxp 已提交
45 46 47
- [W3C 规范](https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/canvas)
- canvas.toDataURL()  [W3C](https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLCanvasElement/toDataURL)
- uni.createCanvasContextAsync 获取[CanvasContext对象](../api/create-canvas-context-async.md)
D
DCloud_LXH 已提交
48
- [CanvasRenderingContext2D对象](../api/canvasrenderingcontext2d.md)
49
- [动画帧](../api/animation-frame.md)
H
hdx 已提交
50

W
wanganxp 已提交
51
## 获取组件上下文对象CanvasContext@CanvasContext
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
52

W
wanganxp 已提交
53
1. 异步方式获取CanvasContext
54

W
wanganxp 已提交
55
这种方式跨平台,一般推荐这种写法。需HBuilderX 4.25+支持。
56 57 58 59 60 61

```html
<template>
  <canvas id="canvas"></canvas>
</template>
<script setup>
W
wanganxp 已提交
62
// HBuilderX 4.25+
63 64 65
// 异步调用方式, 跨平台写法
uni.createCanvasContextAsync({
  id: 'canvas',
66
  component: getCurrentInstance().proxy,
67 68 69 70 71 72 73 74 75 76 77 78 79 80
  success: (context : CanvasContext) => {
    const canvasContext = context.getContext('2d')!;
    const canvas = canvasContext.canvas;

    // 处理高清屏逻辑
    const dpr = uni.getDeviceInfo().devicePixelRatio ?? 1;
    canvas.width = canvas.offsetWidth * dpr;
    canvas.height = canvas.offsetHeight * dpr;
    canvasContext.scale(dpr, dpr); // 仅需调用一次,当调用 reset 方法后需要再次 scale
  }
})
</script>
```

W
wanganxp 已提交
81 82 83 84 85
文档[详见](../api/create-canvas-context-async.md)

2. 同步方式CanvasContext

需HBuilderX 4.21+支持。
86

87
```html
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
88 89
<template>
  <canvas id="canvas"></canvas>
90 91
</template>
<script setup>
92
// 同步调用方式,仅支持 app/web
93 94 95 96
const canvas = uni.getElementById("canvas") as UniCanvasElement
const context = canvas.getContext("2d")!;

// 处理高清屏逻辑
97
const dpr = uni.getDeviceInfo().devicePixelRatio ?? 1;
98 99 100 101 102 103 104
canvas.width = canvas.offsetWidth * dpr;
canvas.height = canvas.offsetHeight * dpr;
context.scale(dpr, dpr); // 仅需调用一次,当调用 reset 方法后需要再次 scale

// 省略绘制代码,和 w3c 规范保持一致
</script>
```
W
wanganxp 已提交
105 106 107

<!-- UTSCOMJSON.canvas.example -->

D
DCloud_LXH 已提交
108
<!-- UTSCOMJSON.canvas.reference -->