uniapp 微信小程序绘制canvas,保存canvas为图片到手机/本地

uniapp

<view style="position: fixed;width: 750rpx;height: 100%;z-index: 0;overflow:hidden;">
			<canvas id="myCanvas" 
					canvas-id="myCanvas" 
					canvas-type="2d" 
<!--漂移出屏幕不直接显示到页面上-->
					style="position: absolute;width: 750px;height: 1334px;left: 9999rpx;"></canvas>
		</view>


<view class="ta-c"
					style="width: 260rpx;
							height: 90rpx;
							line-height: 90rpx;
							margin-right:80rpx;
							color: #fff;
							background: linear-gradient(183deg, #FFFFFF 0%, #FFC066 0%, #FF651C 100%);
							border-radius: 45rpx;"
					@click="writeCanvas">
					保存图片
				</view>

 js

writeCanvas(){
			var that = this;
			new Promise(function(resp,rej){
				uni.getImageInfo({
					src: that.imageUrl,//这里是一张网络图片
					success: (response) => {
						console.log("response=",response)
						resp(response)
					},
				})
			}).then(function(data){
				//myCanvas
				const ctx = wx.createCanvasContext('myCanvas')
				ctx.drawImage(data.path, 0, 0)//将获取到的网络图片的临时图片画到屏幕中
				ctx.draw()
				console.log("draw over")
				that.saveImgToLocal();
			}).catch(function(data){
				console.log("catch",data)
			});
		},
		//保存页面中的myCanvas到本地相册
		saveImgToLocal(){
			//将生成好的图片保存到本地,需要延迟一会,绘制期间耗时
			setTimeout(function() {
				wx.canvasToTempFilePath({
					canvasId: 'myCanvas',
					success: function(res) {
						console.log("save ok canvasToTempFilePath",res)
						var tempFilePath = res.tempFilePath;
						wx.saveImageToPhotosAlbum({
							filePath: tempFilePath,
							success(res) {
								console.log('saveImageToPhotosAlbum', res);
								wx.showToast({
									title: '已保存到相册',
									icon: 'success',
									duration: 2000
								})
							}
						})
					},
					fail: function(res) {
						console.log(res);
					}
				});
			}, 500);
		},

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Uniapp中,实现微信小程序分享图片的流程如下: 1. 首先,使用canvas绘图功能将图片绘制到页面上,并生成一个本地路径。 2. 接下来,将绘制好的图片保存至本地。 3. 最后,由用户自行选择将保存图片分享给朋友或者朋友圈。 除了以上方法,还可以使用mixins文件夹下的share.js文件来定义全局分享内容。在该文件中,可以设置分享的标题、路径、图片链接和描述。然后,通过onShareAppMessage方法实现发送给朋友的分享,通过onShareTimeline方法实现分享到朋友圈的分享。 总结起来,Uniapp微信小程序分享图片的流程包括使用canvas绘图生成本地路径、保存图片至本地、由用户自行分享图片,以及使用全局分享设置进行自定义分享。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [uniapp小程序分享图片](https://blog.csdn.net/m0_49744220/article/details/125769297)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [uniapp 实现微信小程序分享给好友、朋友圈](https://blog.csdn.net/weixin_38982591/article/details/125096377)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值