有意思,圣诞节自己做一个装饰圣诞帽头像的APP!

简介: 有意思,圣诞节自己做一个装饰圣诞帽头像的APP!

项目框架


最近一直迷恋 uni-app,虽然自己还是一个初学者,但是总是隐隐的能感觉到,大前端时代正在走来。没错,今天我们要说的 APP 就是通过 uni-app 来实现的,纯前端代码即可实现!


这里我还是推荐使用 HBuilderX这款编译器,毕竟是真的好用且和 uni-app 项目完美结合,因为都是 DCloud 团队的产品嘛!

下面完美就通过 HBuilderX 来创建一个 uni-app 项目


微信图片_20220521130845.png

对于本程序,我们就采用最简单的方式,一个页面足够了,编辑 pages 当中的 index 中的 index.vue,在这里编写我们程序的页面布局,已经相关的操作

我们先设置页面背景,这个可以定下全局的基调

<image class="page-bg" :style="{ height: windowHeight + 'px'}" mode="aspectFill" src="/static/image/christmas-bg.png"></image>

下面我们布置个人头像

<view class="avatar-container grid justify-center" id="avatar-container" @touchstart="touchStart" @touchend="touchEnd" @touchmove="touchMove">
            <view class="avatar-bg-border">
                <image @touchstart="touchAvatarBg" class="bg avatar-bg" id="avatar-bg" :src="avatarPath"></image>
            </view>
            <image 
                v-if="currentMaskId > -1"
                class="mask flip-horizontal"
                :class="{maskWithBorder: showBorder}"
                id='mask'
                :src="maskPic"
              :style="{ top: maskCenterY-maskSize/2-2+'px', left: maskCenterX-maskSize/2-2+'px', transform: 'rotate(' +rotate+ 'deg)' + 'scale(' +scale+')' + 'rotateY('+ rotateY +'deg)'}"
            ></image>
            <text class="cuIcon-full handle circle" :class="{hideHandle: !showBorder}" id="handle" :style="{top:handleCenterY-10 + 'px', left:handleCenterX-10 +'px'}"></text>
        </view>


对于个人头像,使用 avatarPath 来保存,在后面会给出定义路径

接下来我们定义几个按钮

<view class="grid justify-around action-wrapper">
            <view class="grid col-1">
                <!-- #ifdef MP-WEIXIN -->
                <button id="btn-my-avatar" class="cu-btn round action-btn bg-yellow shadow " open-type="getUserInfo" @getuserinfo="getUserInfo">获取头像</button>
                <!-- #endif -->
                <!-- #ifndef MP-WEIXIN -->
                <button id="btn-my-avatar" class="cu-btn round action-btn bg-yellow shadow " @click="getPic">上传头像</button>
                <!-- #endif -->
            </view>
            <view class="grid col-2">
                <button id="btn-save" class="cu-btn round action-btn bg-yellow shadow" @click="draw">保存头像</button>
            </view>
            <!-- #ifdef APP-PLUS -->
            <view class="grid col-3">
                <button id="btn-save" class="cu-btn round action-btn bg-yellow shadow" open-type="share">分享朋友</button>
            </view>
            <!-- #endif -->
        </view>


在这里,我通过注释法来选择平台,从而调用不同的方法

· 对于微信小程序,按钮的功能是获取用户头像

· 对于 APP 程序,按钮的功能是从本地相册选择图片

下面就是挂件部分

<scroll-view class="scrollView mask-scroll-view" scroll-x="true">
            <view v-for="(item,index) in imgList" :key="index" style="display: inline-flex;">
                <image class="imgList" :src="'/static/image/Christmas/'+ index +'.png'" :data-mask-id="index" @tap="changeMask"></image>
            </view>
        </scroll-view>

在这里把我们准备好的挂件图片通过方法转换长 mask 格式,然后展示在最底部

下面我们来看下 script 部分

首先是

data() {
            return {
                duration: 15,
                windowHeight: 0,
                cansWidth: 270, // 宽度 px
                cansHeight: 270, // 高度 px
                avatarPath: '/static/image/Christmas/avatar_mask.png',
                imgList: range(0, 7, 1), // 第二个参数是个数                
            }
        }


在这里定义了用户初始头像的路径,以及头像挂件的个数

下面是 APP 程序启动时的初始配置

onShareAppMessage() {
            return {
                title: '圣诞节来临,装饰一棵圣诞树吧!',
                imageUrl: '/static/image/Christmas/avatar_mask.png',
                path: '/pages/index/index',
                success: function(res) {
                    console.log(res);
                }
            }
        }


最后我们再简单的看下如何从本地相册获取图片

getPic(result) {
                let self = this;
                uni.chooseImage({
                    count: 1, //默认9
                    sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
                    sourceType: ['album'], //从相册选择
                    success: function (res) {
                            uni.getImageInfo({
                                src: res.tempFilePaths[0],
                                success: function (image) {
                                    self.avatarPath = image.path;
                                }
                            });
                        }
                });
            }

在这里可以直接调用 uni 的 API 接口,chooseImage 可以打开本地相册并选择图片,getImageInfo 可以拿到图片的相关信息

至于如何获取用户微信头像,就不再赘述了,网上有很多例子了!

下面我们来简单看下最后的效果吧

微信图片_20220521130854.png


image.png

点击查看原视频链接

最后,如果想要这款 APP 的话,可以在后台回复“圣诞头像”,如果想要完整代码,可以回复“圣诞代码”

相关文章
|
8月前
uni-app 4.7封装头像组件
uni-app 4.7封装头像组件
75 0
|
JavaScript 数据库
uni-app头像上传(完善个人信息功能),后端NodeJs+MySQL
uni-app头像上传(完善个人信息功能),后端采用的是NodeJs(express.js),数据库采用的是MySQL
|
移动开发 前端开发 API
uin-app如何获取微信昵称和头像的博客
uin-app如何获取微信昵称和头像的博客
|
8月前
|
前端开发 小程序 编译器
有意思,圣诞节自己做一个装饰圣诞帽头像的APP!
有意思,圣诞节自己做一个装饰圣诞帽头像的APP!
|
API
App实现登录页面切换头像的流程
在APP的登录操作中头像可根据用户需求自定义上传图片
130 0
|
人工智能 自然语言处理 机器人
Midjourney|文心一格prompt教程[Text Prompt(上篇)]:品牌log、App、徽章、插画、头像场景生成,各种风格选择:科技风、运动风
Midjourney|文心一格prompt教程[Text Prompt(上篇)]:品牌log、App、徽章、插画、头像场景生成,各种风格选择:科技风、运动风
Midjourney|文心一格prompt教程[Text Prompt(上篇)]:品牌log、App、徽章、插画、头像场景生成,各种风格选择:科技风、运动风
|
安全 JavaScript 前端开发
APP渗透测试 头像上传漏洞检测与修复
多客户网站以及APP在上线运营之前都会对网站进行渗透测试,提前检测网站是否存在漏洞,以及安全隐患,避免因为网站出现漏洞而导致重大的经济损失,客户找到我们SINE安全做渗透测试服务的时候,我们都会对文件上传功能进行全面的安全测试,包括文件上传是否可以绕过文件格式,上传一些脚本文件像php,jsp,war,aspx等等,绕过上传目录,直接上传到根目录下等等的一些漏洞检测。
399 0
APP渗透测试 头像上传漏洞检测与修复
仿抖音短视频APP源码,实现简单的换头像并保存
仿抖音短视频APP源码,实现简单的换头像并保存
420 0
|
2天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
|
1天前
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
8 1