


Take you step by step to implement the small program for making avatar frame for the Year of the Tiger (Practice)
Jan 19, 2022 am 10:29 AMThe Spring Festival of the Year of the Tiger is coming soon. How to add the Year of the Tiger avatar frame to the picture. The following article will show you how to make a small program to realize this function. I hope it will be helpful to you!
It’s the end of another year. It feels like time is passing by so fast. One year is gone in a flash, and another year is gone in a flash.
I remember that I didn’t go home to celebrate the New Year last year due to the epidemic. On the night of New Year’s Eve, I posted a small program in the family WeChat group to get red envelopes by playing games. It was also very happy.
Although I have never developed small games myself, I have written some small programs. Recently, I have seen many friends change their New Year avatars. Just like the following:
# After looking at it, there are mainly two parts: picture, photo frame, overlay and save as one picture, then I can also implement one.
So there is this article, a homemade Year of the Tiger avatar frame applet.
Realization
Without further ado, let’s start with the renderings.
1. Implementation principle
As you can see from the renderings, two methods are used here. Pictures:
One is the avatar of a WeChat user obtained through the "Get Avatar" button, used as a base map;
The other is a photo frame picture, which is a pre-made static resource;
When you click "Save Avatar", draw the above two pictures to the drawing board through canvas. First draw the base picture, and then draw the photo frame. After the drawing is completed, save the pictures on the drawing board locally. It's done.
The specific implementation steps will be introduced below.
2. Collect static resources
There are some static resources built into my small program. For example: avatar frame picture, homepage background picture, bottom navigation bar icon, etc.
These pictures are from the following websites and are for reference only.
Alibaba VectorIcon Library
https://www.iconfont.cn/
A good place to get icons .
千圖網(wǎng)
https://www.58pic.com/
A good place to get background pictures, avatar frames, etc.
3. Coding
is divided into three parts to introduce the coding stage.
3.1 Obtain WeChat user avatar
The WeChat applet provides an API to obtain WeChat user information. wx.getUserProfile(Object object)
Get WeChat user information by clicking the button button:
<button bindtap="getUserProfile" class="btn1">獲取頭像</button>
getUserProfile is implemented as follows:
// 推薦使用wx.getUserProfile獲取用戶信息,開發(fā)者每次通過該接口獲取用戶個人信息均需用戶確認 getUserProfile(e) { let that = this; wx.getUserProfile({ desc: '僅用于生成頭像使用', // 聲明獲取用戶個人信息后的用途,后續(xù)會展示在彈窗中,請謹慎填寫 success: (res) => { //獲取高清用戶頭像 let 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; that.setData({ userInfo: res.userInfo, hasUserInfo: true }) } }); },
Getting the WeChat user avatar here has been completed.
Note: The user avatar returned by res.userInfo is low-resolution by default, and processing is required to obtain a high-definition image of the user avatar.
3.2 Drawing images
Drawing images mainly use the Canvas related API provided by the WeChat applet (https://developers.weixin .qq.com/miniprogram/dev/api/canvas/wx.createOffscreenCanvas.html)
Variable description:
hotArr:[{name:'Year of the Tiger Photo Frame ',key:'hunian'},{name:'tiger head hat',key:'shendan'},{name:'national flag',key:'guoqing'}],
curHot: used for Stores the index of the currently selected hotArr.
windowWidth: wx.getSystemInfoSync().windowWidth
size: 260; //Customized size
pc : wx.createCanvasContext('myCanvas');
drawImg(){ wx.showLoading({ title: '生成頭像中...', }) let that = this; let type = this.data.hotArr[this.data.curHot].key; let promise1 = new Promise(function(resolve, reject) { wx.getImageInfo({ src: that.data.userInfo.avatarUrl, success: function(res) { resolve(res); } }) }); var index = that.data.defaultImg; let promise2 = new Promise(function(resolve, reject) { wx.getImageInfo({ src: `../../images/${type}/hat${index}.png`, success: function(res) { resolve(res); } }) }); Promise.all([ promise1, promise2 ]).then(res => { //主要就是計算好各個圖文的位置 pc.clearRect(0, 0, windowWidth, size); //繪制背景圖 pc.drawImage(res[0].path, windowWidth/2-130, 0, size, size) //繪制相框圖 pc.drawImage('../../' + res[1].path, windowWidth/2-130, 0, size, size) pc.stroke() pc.draw(false, () => { //圖片繪制成功回調(diào),調(diào)用保存canvas方法 this.canvasToTempFile(); }) }) },
wx.getImageInfo() is mainly used to obtain image information and return the local path of the image;
This place is mainly because drawImage() Only supports drawing local images.
3.3 Save the image
In the previous step we have drawn two pictures onto the canvas, now we will save the contents on the canvas locally.
Saving the content on the canvas to the local album is also divided into two steps.
Step one: Export the contents of the specified area of ??the current canvas to generate a picture of the specified size.
通過使用 wx.canvasToTempFilePath()
第二步:將保存圖片本地相冊。
通過使用 wx.saveImageToPhotosAlbum(https://developers.weixin.qq.com/miniprogram/dev/api/media/image/wx.saveImageToPhotosAlbum.html)
canvasToTempFile(){ wx.canvasToTempFilePath({ x: windowWidth/2-130, //這個地方減去130是因為我們的圖片尺寸設(shè)置的是260 y: 0, height: size, width: size, canvasId: 'myCanvas', success: (res) => { wx.saveImageToPhotosAlbum({ filePath: res.tempFilePath, success: result => { wx.hideLoading(); wx.showModal({ content: '圖片已保存到相冊,請前往微信去設(shè)置喲!', showCancel: false, success: function(res) { if (res.confirm) { console.log('用戶點擊確定'); } } }) }, fail(e) { wx.hideLoading(); console.log("err:" + e); } }) } }); },
到這里也就實現(xiàn)了基本的頭像框功能。
最后
感興趣的小伙伴可以掃碼體驗:
當(dāng)然了,基于上面的內(nèi)容你也可以制作自己的頭像小程序。
最后 提前恭祝大家春節(jié)快樂,虎年大吉?。?!
【相關(guān)學(xué)習(xí)推薦:小程序開發(fā)教程】
The above is the detailed content of Take you step by step to implement the small program for making avatar frame for the Year of the Tiger (Practice). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

With the popularity of mobile Internet technology and smartphones, WeChat has become an indispensable application in people's lives. WeChat mini programs allow people to directly use mini programs to solve some simple needs without downloading and installing applications. This article will introduce how to use Python to develop WeChat applet. 1. Preparation Before using Python to develop WeChat applet, you need to install the relevant Python library. It is recommended to use the two libraries wxpy and itchat here. wxpy is a WeChat machine

Implementing card flipping effects in WeChat mini programs In WeChat mini programs, implementing card flipping effects is a common animation effect that can improve user experience and the attractiveness of interface interactions. The following will introduce in detail how to implement the special effect of card flipping in the WeChat applet and provide relevant code examples. First, you need to define two card elements in the page layout file of the mini program, one for displaying the front content and one for displaying the back content. The specific sample code is as follows: <!--index.wxml-->&l

According to news from this site on October 31, on May 27 this year, Ant Group announced the launch of the "Chinese Character Picking Project", and recently ushered in new progress: Alipay launched the "Chinese Character Picking-Uncommon Characters" mini program to collect collections from the society Rare characters supplement the rare character library and provide different input experiences for rare characters to help improve the rare character input method in Alipay. Currently, users can enter the "Uncommon Characters" applet by searching for keywords such as "Chinese character pick-up" and "rare characters". In the mini program, users can submit pictures of rare characters that have not been recognized and entered by the system. After confirmation, Alipay engineers will make additional entries into the font library. This website noticed that users can also experience the latest word-splitting input method in the mini program. This input method is designed for rare words with unclear pronunciation. User dismantling

Mini programs can use react. How to use it: 1. Implement a renderer based on "react-reconciler" and generate a DSL; 2. Create a mini program component to parse and render DSL; 3. Install npm and execute the developer Build npm in the tool; 4. Introduce the package into your own page, and then use the API to complete the development.

How uniapp can achieve rapid conversion between mini programs and H5 requires specific code examples. In recent years, with the development of the mobile Internet and the popularity of smartphones, mini programs and H5 have become indispensable application forms. As a cross-platform development framework, uniapp can quickly realize the conversion between small programs and H5 based on a set of codes, greatly improving development efficiency. This article will introduce how uniapp can achieve rapid conversion between mini programs and H5, and give specific code examples. 1. Introduction to uniapp unia

This article brings you some related issues about WeChat mini programs. It mainly introduces how to use official account template messages in mini programs. Let’s take a look at them together. I hope it will be helpful to everyone.

Implementation idea: Establishing the server side of thread, so as to process the various functions of the chat room. The establishment of the x02 client is much simpler than the server. The function of the client is only to send and receive messages, and to enter specific characters according to specific rules. To achieve the use of different functions, therefore, on the client side, you only need to use two threads, one is dedicated to receiving messages, and the other is dedicated to sending messages. As for why not use one, that is because, only

Geolocation positioning and map display of PHP and mini programs Geolocation positioning and map display have become one of the necessary functions in modern technology. With the popularity of mobile devices, people's demand for positioning and map display is also increasing. During the development process, PHP and applets are two common technology choices. This article will introduce you to the implementation method of geographical location positioning and map display in PHP and mini programs, and attach corresponding code examples. 1. Geolocation in PHP In PHP, we can use third-party geolocation
