开发者社区
社区提问意见反馈
开发者钉组织
扫描二维码
加入支付宝开发者钉组织
基础 api
基础
应用级事件
界面
导航栏
tabbar
路由
交互反馈
下拉刷新
联系人
选择城市
选择日期
动画
画布
canvas
canvasrenderingcontext2d
canvaspattern
offscreencanvas
旧版接口(停止更新)
canvascontext
canvasgradient
地图
计算路径
键盘
滚动
节点查询
选项选择器
级联选择
设置窗口背景
设置页面是否支持下拉
字体
跳转
多媒体
缓存
文件
位置
网络
设备
worker
数据安全
分享
收藏
自定义通用菜单
更新管理
web-view组件控制
升级支付宝最新版本
隐私信息授权
小程序广告
开放能力 api
开发 > api > 基础 api > 界面 > 画布 > 旧版接口(停止更新) > my.canvastotempfilepath
评论
收藏
我的文档
设置

my.canvastotempfilepath(object object)

主体: 企业支付宝小程序个人支付宝小程序

将画布指定区域保存为图片。

此接口同时兼容新版和旧版画布的使用。关于新旧版本接口的差异和升级方法,请参考 旧版 canvas 迁移指南

object object

属性 类型 默认值 必填 兼容性 描述
canvasid string - -

要提取的画布的 id。基于旧版画布使用时必填

canvas canvas -
基础库: 2.7.15
支付宝: 10.2.35

要提取的画布的实例。基于新版画布使用时必填

x number 0 -

指定的画布区域的左上角横坐标

y number 0 -

指定的画布区域的左上角纵坐标

width number canvas宽度-x -

指定的画布区域的宽度

height number canvas高度-y -

指定的画布区域的高度

destwidth number width*屏幕像素密度 -

输出的图片的宽度

destheight number height*屏幕像素密度 -

输出的图片的高度

filetype string png -

导出的图片的类型

枚举值 描述 兼容性
jpg

.jpg 图片

-
png

.png 图片

-
quality number 1 -

导出图片的质量。仅当 filetype 为 jpg 时有效。合法值为 (0, 1],不在范围内时当作 1 处理

success function - -

调用成功的回调函数

fail function - -

调用失败的回调函数

complete function - -

调用结束的回调函数(调用成功、失败都会执行)

success 回调函数

参数

object res

属性 类型 描述
apfilepath string

图片路径(本地临时文件)

新版画布使用
旧版画布使用
.js
.axml
page({
    oncanvasready() {
        my.createselectorquery().select('#canvas').node().exec((res) => {
            const canvas = res[0].node
            var ctx = canvas.getcontext('2d')
            let img = canvas.createimage()
            img.src = "https://mdn.alipayobjects.com/huamei_esgcm9/afts/img/a*ouykq5wgy-aaaaaaaaaaaaaadsajaq/original"
            img.onload = function () {
                ctx.drawimage(img, 0, 0)
                my.canvastotempfilepath({
                    canvas: canvas,
                    x: 0,
                    y: 0,
                    width: 300,
                    height: 250,
                    filetype: 'jpg',
                    quality: 1,
                    success: (res) => {
                        console.log('res', res.apfilepath)
                    }
                })
            }
        })
    }
})
<canvas id="canvas" type="2d" onready="oncanvasready">canvas>
.js
.axml
page({
    onready() {
        const ctx = my.createcanvascontext('canvas')
        ctx.drawimage('https://mdn.alipayobjects.com/huamei_esgcm9/afts/img/a*s8quqr2unzaaaaaaaaaaaaaadsajaq/original', 10, 10, 250, 80)
        ctx.draw(true, () => {
            my.canvastotempfilepath({
                canvasid: 'canvas',
                x: 0,
                y: 0,
                width: 300,
                height: 250,
                filetype: 'jpg',
                quality: 1,
                success: (res) => {
                    console.log('res', res.apfilepath)
                },
            })
        })
    }
})
<canvas id="canvas">canvas>
  • tip
    真机中保存图片后返回的文件扩展名为 .image,而非图片真实扩展名。若需判断文件真实扩展名,可使用 my.detectfiletype
内容没有解决您的问题?您还可以前往 或 寻求帮助
凯发k8官方网娱乐官方 copyright © 2022 支付宝(杭州)信息技术有限公司  | icp证浙b2-20160559
该文档对你是否有帮助?
当前页面目录
网站地图