• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 带你开发一个虎年春节头像生成小程序

带你开发一个虎年春节头像生成小程序

作者:站长图库 字体:[增加 减小] 来源:互联网

站长图库向大家介绍了虎年春节小程序,头像生成小程序等相关知识,希望对您有所帮助

本篇文章带大家跟风做一个虎年春节头像制作小程序,获取微信头像,选择头像边框,即可合成不同的虎年春节头像,希望对大家有所帮助!

马上就到春节了,今天看到有网友分享了网页版的虎年头像制作工具,感觉很不错,正好打算做个小程序练手没啥主题,那就用这个试试吧。

先上最终效果图:


带你开发一个虎年春节头像生成小程序


实现流程

第一步:先获取到当前微信的头像图片,主要代码如下,注意默认获取到的头像图片不是高清的,需要先转换成高清图片,避免生成之后很模糊。

getUserProfile(e) {    console.log(e)    let that = this;    wx.getUserProfile({      desc: '仅用于生成头像使用',      success: (res) => {        var url = res.userInfo.avatarUrl;        while (!isNaN(parseInt(url.substring(url.length - 1, url.length)))) {          url = url.substring(0, url.length - 1)        }        url = url.substring(0, url.length - 1) + "/0";        res.userInfo.avatarUrl = url;        console.log(JSON.stringify(res.userInfo));        that.setData({          userInfo: res.userInfo,          hasUserInfo: true        })        that.drawImg();      }    });},

第二步:合成头像,把素材图片和第一步获取到的头像图片,获取到本地文件,然后利用小程序的cavas组件进行合成。

drawImg() {    let that = this;    wx.showLoading({      title: '生成头像中...',    })    let promise1 = new Promise(function (resolve, reject) {      wx.getImageInfo({        src: that.data.userInfo.avatarUrl,        success: function (res) {          resolve(res);        }      })    });    var mask_id = that.data.now_mask;    let promise2 = new Promise(function (resolve, reject) {      wx.getImageInfo({        src: `../../assets/img/mask0${mask_id}.png`,        success: function (res) {          console.log(res)          resolve(res);        }      })    });    Promise.all([      promise1, promise2    ]).then(res => {      console.log(res)      var windowWidth = wx.getSystemInfoSync().windowWidth      var context = wx.createCanvasContext('myAvatar');      var size = windowWidth /750 * 500      // var size = 500      context.drawImage(res[0].path, 0, 0, size, size);      context.draw(true)      context.save();      context.drawImage('../../'+res[1].path, 0, 0, size, size);      context.draw(true)      context.save();    })    wx.hideLoading()},

第三步:下载合成的图片到本地相册。

canvasToTempFile(){    if(!this.data.userInfo){      wx.showModal({        title: '温馨提示',        content: '请先点击上方获取微信头像',        showCancel: false,      })      return    }    var windowWidth = wx.getSystemInfoSync().windowWidth    var size = 500    // var dpr = 750 / windowWidth    wx.canvasToTempFilePath({      x: 0,      y: 0,      height: size,      width: size,      canvasId: 'myAvatar',      success: (res) => {        wx.saveImageToPhotosAlbum({          filePath: res.tempFilePath,          success: result => {            wx.hideLoading();            wx.showModal({              content: '图片已保存到相册,请前往微信去设置哟!',              showCancel: false,              success: function(res) {                if (res.confirm) {                  console.log('用户点击确定');                }              }            })          }, fail(e) {            wx.hideLoading();            console.log("err:" + e);          }        })      }    });},

这样就实现了主要的功能了。

最后 当前项目已开源:hackun666/new-year-face: wechat new year face maker (github.com)


原文地址:https://juejin.cn/post/7057

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 带你开发一个虎年春节头像生成小程序

相关文章

  • 详解thinkphp5.1的URL重写,伪静态设置
  • ThinkPHP6通过Ucenter实现注册登录的示例代码
  • dede 安全设置集合!dede站长必看!
  • Photoshop制作圆形炫彩LOGO教程
  • Photoshop制作3D小人推动切割的艺术字教程
  • php怎么将ppt转jpg图片
  • 详解如何提升WordPress打开前后台的速度
  • SQL语言中,删除一个表的命令是什么
  • 网站上线前需要做的优化准备工作
  • 浅谈nodejs利用node-xlsx模块读取excel数据的方法

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • PS抠图插件Topaz ReMask滤镜抠图使用图文教程
    • DEDECMS修改提示信息方法
    • 如何在PHP中获取数组单元数量
    • PS制作梦幻五彩斑斓的霓虹灯文字效果教程
    • Mysql如何允许外网访问设置
    • PS打造动感抽象炫光舞者海报效果制作教程
    • 教你使用PHP数据库迁移工具“Phinx”
    • 简单聊聊Redis中GETBIT和SETBIT
    • Photoshop合成抽象风格的人物插画教程
    • PS教程:如何打造逼真的冰冻效果

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有