本文实例为大家分享了微信小程序实现加入购物车滑动轨迹的具体代码,供大家参考,具体内容如下
index.wxss
.good_box { width: 80rpx; height: 80rpx; position: fixed; border-radius: 50%; overflow: hidden; left: 50%; top: 50%; z-index: 99; }
index.wxml
<view class="iconfont icongouwuche recommend_item_shopcar" bindtap="touchOnGoods"></view> <view class="good_box" hidden="{{hide_good_box}}" style="left: {{bus_x}}px; top: {{bus_y}}px;"> <image class="image" src="/UploadFiles/2021-04-02/luntai2.png">**app.js **
//app.js App({ onLaunch: function() { //调用API从本地缓存中获取数据 // var logs = wx.getStorageSync('logs') || [] // logs.unshift(Date.now()) // wx.setStorageSync('logs', logs) this.screenSize(); }, getUserInfo: function(cb) { var that = this if (this.globalData.userInfo) { typeof cb == "function" && cb(this.globalData.userInfo) } else { //调用登录接口 wx.login({ success: function() { wx.getUserInfo({ success: function(res) { that.globalData.userInfo = res.userInfo typeof cb == "function" && cb(that.globalData.userInfo) } }) } }) } }, //获取屏幕[宽、高] screenSize: function() { var that = this; wx.getSystemInfo({ success: function(res) { that.globalData.ww = res.windowWidth; that.globalData.hh = res.windowHeight; } }) }, /** * @param sx 起始点x坐标 * @param sy 起始点y坐标 * @param cx 控制点x坐标 * @param cy 控制点y坐标 * @param ex 结束点x坐标 * @param ey 结束点y坐标 * @param part 将起始点到控制点的线段分成的份数,数值越高,计算出的曲线越精确 * @return 贝塞尔曲线坐标 */ bezier: function(points, part) { let sx = points[0]['x']; let sy = points[0]['y']; let cx = points[1]['x']; let cy = points[1]['y']; let ex = points[2]['x']; let ey = points[2]['y']; var bezier_points = []; // 起始点到控制点的x和y每次的增量 var changeX1 = (cx - sx) / part; var changeY1 = (cy - sy) / part; // 控制点到结束点的x和y每次的增量 var changeX2 = (ex - cx) / part; var changeY2 = (ey - cy) / part; //循环计算 for (var i = 0; i <= part; i++) { // 计算两个动点的坐标 var qx1 = sx + changeX1 * i; var qy1 = sy + changeY1 * i; var qx2 = cx + changeX2 * i; var qy2 = cy + changeY2 * i; // 计算得到此时的一个贝塞尔曲线上的点 var lastX = qx1 + (qx2 - qx1) * i / part; var lastY = qy1 + (qy2 - qy1) * i / part; // 保存点坐标 var point = {}; point['x'] = lastX; point['y'] = lastY; bezier_points.push(point); } //console.log(bezier_points) return { 'bezier_points': bezier_points }; }, globalData: { ww:'', hh:'' } })index.js
//index.js //获取应用实例 const app = getApp() Page({ data: { indicatorDots: true, vertical: false, autoplay: false, interval: 2000, duration: 500, hide_good_box: true, }, onLoad: function () { this.busPos = {}; this.busPos['x'] = app.globalData.ww / 1.4; //1.4修改轨迹结束时x轴的位置,2是在正中心 this.busPos['y'] = app.globalData.hh - 10; console.log('购物车坐标', this.busPos) }, onShow(){ app.editTabBar(); //显示自定义的底部导航 }, tosearchpage(e){ wx.navigateTo({ url: '', }) }, touchOnGoods: function (e) { // 如果good_box正在运动 if (!this.data.hide_good_box) return; this.finger = {}; var topPoint = {}; this.finger['x'] = e.touches["0"].clientX; this.finger['y'] = e.touches["0"].clientY; if (this.finger['y'] < this.busPos['y']) { topPoint['y'] = this.finger['y'] - 150; } else { topPoint['y'] = this.busPos['y'] - 150; } topPoint['x'] = Math.abs(this.finger['x'] - this.busPos['x']) / 2; if (this.finger['x'] > this.busPos['x']) { topPoint['x'] = (this.finger['x'] - this.busPos['x']) / 2 + this.busPos['x']; } else { topPoint['x'] = (this.busPos['x'] - this.finger['x']) / 2 + this.finger['x']; } this.linePos = app.bezier([this.finger, topPoint, this.busPos], 20); this.startAnimation(); }, startAnimation: function () { var index = 0, that = this, bezier_points = that.linePos['bezier_points'], len = bezier_points.length - 1; this.setData({ hide_good_box: false, bus_x: that.finger['x'], bus_y: that.finger['y'] }) this.timer = setInterval(function () { index++; that.setData({ bus_x: bezier_points[index]['x'], bus_y: bezier_points[index]['y'] }) if (index >= len) { clearInterval(that.timer); that.setData({ hide_good_box: true, }) } }, 15); }, })为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月14日
2024年11月14日
- 张敬轩王菀之.2006-903.ID.CLUB拉阔演奏厅LIVE.2CD【环球】【WAV+CUE】
- 《欢欣森活》存档方法
- 《炉石传说》2024新赛季上线更新内容问题汇总
- 《南瓜恐慌》进不去游戏解决方法
- 杨烁《杨烁唱唐诗》2024Hi-Res[WAV分轨]
- 杨烁《杨烁唱唐诗》2024Hi-Res[WAV分轨]
- 童丽《民歌童丽(HQCD)》【WAV+CUE】
- 童丽《绝对收藏》2022头版限量编号[WAV+CUE][1G]
- 腾格尔《出走天堂》MQA-UHQCD限量版[低速原抓WAV+CUE][1G]
- 田震《时光音乐会》纯银CD[低速原抓WAV+CUE][1G]
- 炉石传说11月初最强登顶卡组合集 炉石传说11月初登顶卡组分享
- lol炼金龙魂详细属性是什么 2024炼金龙魂详细属性介绍
- 英雄联盟六个龙魂是哪六个 英雄联盟六个龙魂介绍一览
- 《忆蚀》Subliminal:揭秘后室之谜,路知行献声Weplay文化展
- 初始之部制作人气漫画改编游戏《我家大师兄脑子有坑》参展2024WePlay