小程序利用canvas 绘制图案 (生成海报,生成有特色的头像)微信小程序生成特色头像,海报等是比较常见的 。下面我来介绍下实现该类小程序的过程 。
- 首先选择前端来通过 canvas 绘制 。这样比较节省成本,效率也高 。
- 小程序使用uniapp 来进行开发,方便后期打包为微信,百度等小程序 。
- 可以扫码体验下 我的小程序 制作个性化的头像,
文章插图
- 下面介绍使用 wxml2canvas 生成头像的小程序的制作过程
- 使用HBuilderX 创建一个 uni-app 的项目,可以参照uniapp 官网 。
- 下载项目使用的依赖 npm init 创建package.json
- yarn add less wxml2canvas
- 首先思路是上传一张自己想做为头像的图片
- 然后选择自己想给该图片添加的元素,利用css 定位,使图片位置重叠,产生新的效果
- 讲最新的效果生成图片,并下载 。
- 使用微信头像的方案
wxLogin() {let _this= this;wx.getUserProfile({desc: '获取你的头像',success: res => {console.log(res)_this.headUrl = res.userInfo.avatarUrl},fail: () => {//拒绝授权wx.showToast({title: '您拒绝了请求,不能获取你的头像',icon: 'error',duration: 2000});return;}});},
- 用户自己上传图片,可以直接从相册中选择,也可以使用相机 。
pictureClick (selectid) {const _this = this;let typelist = selectid === 1 ? ['camera'] : ['album']uni.chooseImage({count: 1,sourceType: typelist, //这要注意,camera掉拍照,album是打开手机相册crop: {width: 320,height: 320},success: (res)=> {_this.$refs.gmyImgCropper.chooseImage(res)}});},
- 自己上传的图片,需要使用canvas 来进行裁剪为头像比列相同的图片
<imgCropper ref="gmyImgCropper" :quality="1" cropperType="fixed" :imgSrc="http://shimg.jingyanzongjie.com/230728/00414KK6-1.jpg" @getImg="getImg"></imgCropper>// 上面 是裁剪图片的组件,篇幅较大,可以参考项目源码
利用css 定位生成效果图<view class="head-box" :style="{marginTop: headboxStyle, height: showImgW}"><canvas canvas-id="myCanvas" class="myCanvas" :style="{width: showImgW, height: showImgW}"></canvas><viewclass="showimg showimg-box head-img-border" :style="{width: showImgW, height: showImgW}"><pickerselect@modelselect="modelselect"><view class="showimg normalimgbox" :style="{width: showImgW, height: showImgW, background: currentInfo.iconColor}"><image class="headimg normalimg"src="http://shimg.jingyanzongjie.com/230728/00414IN1-2.png"/></view><view id="my-canvas" class="my_canvas"><view class="showimg" :style="{width: showImgW, height: showImgW}"><image mode="aspectFill " data-type="image" :data-url="headUrl"class="headimg my_draw_canvas" :src="http://shimg.jingyanzongjie.com/230728/00414KK6-1.jpg"/></view><view class="showimg" :style="{width: showImgW, height: showImgW}"><image mode="heightFix" data-type="image" :data-url="selectimg" class="headimg my_draw_canvas" :src="http://shimg.jingyanzongjie.com/230728/00414H323-4.jpg"/></view></view></pickerselect></view></view>
利用wxml2canvas 生成最终的头像图片import Wxml2Canvas from 'wxml2canvas'export const startDraw = ()=> {let that = this// 创建wxml2canvas对象let drawMyImage = new Wxml2Canvas({element: 'myCanvas', // canvas的id,obj: that, // 传入当前组件的thiswidth: 200* 2,height: 200 * 2,background: '#141415', // 生成图片的背景色progress(percent) { // 进度console.log(percent);},finish(url) { // 生成的图片wx.hideLoading()savePoster(url)},error(res) { // 失败原因console.log(res);wx.hideLoading()}}, this);let data = https://www.huyubaike.com/biancheng/{// 获取wxml数据list: [{type:'wxml',class: '.my_canvas .my_draw_canvas',// my_canvas要绘制的wxml元素根类名,my_draw_canvas单个元素的类名(所有要绘制的单个元素都要添加该类名)limit: '.my_canvas', // 要绘制的wxml元素根类名x: 0,y: 0}]}// 绘制canvasdrawMyImage.draw(data, this);}export const drawMyCanvas = () => {wx.showLoading()const that = thiswx.createSelectorQuery().select('#my-canvas') // 在 WXML 中填入的 id.fields({ scrollOffset: true, size: true }, () => {startDraw()}).exec(() => {console.log(888)})}
经验总结扩展阅读
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 2022年第22号台风“尼格”在西北太平洋洋面上生成
- 小吃店名字简单大气 有特色的小吃店名字
- vs 自定义代码块
- 微信怎么没有截图功能啊,我要截图怎么弄(微信限额截图生成器)
- 2022立冬海报的祝福语
- 2022十一月海报的祝福语
- 十一月的主题海报祝福句子
- 生成器函数 javascript异步编程之generator与asnyc/await语法糖
- 临沂有哪些土特产 临沂最有特色的5种特产排行榜
- 大连最有特色的小吃有哪些 大连最出名的六大特色名小吃排行榜