小程序实现绘制图片 保存到手机

 HTML

<template>
	<view>
		<canvas canvas-id="myCanvas" :style="{height:'380px',width:wWidth+'px',background:'#FFFFFF'}"></canvas>
		<view class="textCenter">
			<button @click="saveCanvas">保存图片</button>
		</view>
	</view>
</template>

JS

<script>
	export default {
		data() {
			return {
				wHeight:'',
				wWidth:''
			}
		},
		onLoad(){
			this.wHeight=uni.getWindowInfo().screenHeight-50; //屏幕可视区域高度
			this.wWidth=uni.getWindowInfo().screenWidth;//屏幕可视区域宽
			// 获取Canvas对象 
			var context = wx.createCanvasContext('myCanvas') 
            //设置背景颜色是白色,这个地方就是设置一个与canvas画布一样大小的方框设置方框背景
			context.setFillStyle('#FFFFFF')
			context.fillRect(0,0,this.wWidth,380);
			context.stroke()

			// 绘制文本			
			context.setFontSize(20)			
			context.setFillStyle('red')
			context.setTextAlign('center')
			context.fillText('Hello World!',  this.wWidth/2, 50) 
			
			context.setFontSize(20)
			
			context.setFillStyle('red')
			context.setTextAlign('center')
			
			context.fillText('葫芦娃', this.wWidth/2, 100)
			context.stroke() 
			let _this=this;
			// 绘制图片
			wx.getImageInfo({
				src: 'https://yujia-shanghai-bucket.oss-cn-shanghai.aliyuncs.com/h5/out_program/1687242451873_634a7025d03364b415b90bf5a07306071827dbc97358-C6odDl_fw1200.webp.jpg',
				success(res) { 
					context.drawImage(res.path, _this.wWidth/2-100, 140, 200, 200) 
					context.stroke() 
					// 将Canvas绘制出来 
					context.draw()
				}			
			}) 
		},
		methods: {
			saveCanvas(){
				wx.canvasToTempFilePath({  
					x: 0,  
					y: 0,  
					width: this.wWidth, 
					height: 380,  
					canvasId: 'myCanvas',  
					fileType:'jpg',
					success: function (res) {  
						console.log(res.tempFilePath);  
						wx.saveImageToPhotosAlbum({
							filePath: res.tempFilePath,
						    success: (resS) => {    
							    console.log(resS)  
							    uni.showToast({
								    title:'保存成功',
								    icon:'success'
							    })
						    },  
						    fail: (errS) => {
							
						    }}) 
					    },fail: (err) => {
						    console.log(err);
					    }  
				    }) 
				    return;
				
			    }
		    }
	    }
</script>

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
微信小程序实现保存图片功能的基本步骤如下: 1. 在小程序的页面中,首先需要引入 `wx.canvas` 用于绘制保存图片。 2. 在页面中创建一个 `<canvas>` 标签,设置宽高和唯一的 `canvas-id`。 3. 在 `<canvas>` 中使用 `wx.createContext` 创建绘图上下文对象。 4. 使用绘图上下文对象的 `drawImage` 方法将图片绘制到 `<canvas>` 中。 5. 创建一个按钮或其他触发保存操作的交互元素,并在点击事件中编写保存图片的逻辑。 6. 在点击事件中,使用 `wx.canvasToTempFilePath` 方法将 `<canvas>` 中的内容保存为临时文件路径。 7. 使用 `wx.saveImageToPhotosAlbum` 方法将临时文件保存到用户相册中。 下面是一个实现保存图片功能的示例代码: ```javascript // 在页面中的 js 文件中 Page({ saveImage: function() { const ctx = wx.createCanvasContext('myCanvas', this); // 绘制图片canvas ctx.drawImage('/path/to/image.jpg', 0, 0, 300, 200); // 绘制完成后调用 draw 方法 ctx.draw(false, () => { // 将 canvas 中的内容保存为临时文件 wx.canvasToTempFilePath({ canvasId: 'myCanvas', success: (res) => { // 保存临时文件到用户相册 wx.saveImageToPhotosAlbum({ filePath: res.tempFilePath, success: (res) => { wx.showToast({ title: '保存成功', icon: 'success', duration: 2000 }); }, fail: (err) => { console.error(err); } }); }, fail: (err) => { console.error(err); } }, this); }); } }); ``` 在上述代码中,点击 `saveImage` 按钮会执行保存图片的逻辑,将图片绘制到 `<canvas>` 中,然后将 `<canvas>` 中的内容保存为临时文件,并最终保存到用户的相册中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路光.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值