html5小程序飞入购物车(抛物线绘制运动轨迹点)


Posted in HTML / CSS onOctober 19, 2020

前言:最近有朋友在做小程序的过程中,遇到开发过飞入购物车效果的功能的需求。针对这个情况一些网上的demo,多少会有一些不符合情景的问题(bug)存在,针对这一情况小编决定帮朋友写一个方案来帮助解决问题。

思考如果实现 ? 超级简单的!

无论是小程序还是h5飞入购物车无非就是 平抛 ,或者是 上抛 两种情况,对于这两种情况,初中就开始学习抛物线理论知识是完全可以搞定的,高中一年级物理学的自由落体运动,平抛运动就是抛物线理论的具体实现。

平抛运动

html5小程序飞入购物车(抛物线绘制运动轨迹点)

上抛运动

html5小程序飞入购物车(抛物线绘制运动轨迹点)

构建虚拟直角坐标系,抛物线绘制轨迹点

此方案的本质就是,根据购物车起点和终点,分别做为抛物线的两点,这样一个感念就是要以起始点作为直角坐标系(0,0)方便后续其他坐标点的运算。还有一个应该注意的是,如果是配置了上抛h偏移量 ,就要求最高点(顶点)坐标 此方案均适合 H5 ,小程序

/**
* 飞入购物车,轨迹点绘制
* @author  ?
* @param {Array} start`在这里插入代码片`Point 起点clientX, clientY值 (必要) 
* @param {Array} endPoint   终点clientX, clientY值 (必要)
* @param {number} point     点数          (必要) 
* @param {number} h         抛物线向上高度(上抛运动)  (可选)
* @param {number} hclientX  当存在h情况下,达到最高点时候的clientX值
* @return {Array}  [ left ,top ] 值组成的数组
*/
function flycart(startPoint, endPoint, point, h = 0, hclientX) {
   /* 
   设置startPoint 为(0,0)点 , 此抛物线经过(0,0)点 ,可以推到出模型关系式 y =  ax^2 + bx 或者 y = ax^ 2
   1 当存在 h 的情况,抛物线会y轴向上偏移 h, 此时的关系式 y = ax^2 + bx
   2 当不存在h 的情况 ,抛物线startPoint为顶点, 此时关系式 y = ax^2 
   */

   /* 参数校验 */
   function Validityparameter() {
       let isOkey = true
       Array.isArray(startPoint) && startPoint.length !== 2 && (isOkey = false)
       Array.isArray(endPoint) && endPoint.length !== 2 && (isOkey = false)
           (point.constructor !== Number) && (isOkey = false)
       return isOkey
   }

   /* 参数验证 */
   if (!Validityparameter()) {
       return []
   }

   /* A点横坐标 */
   const xA = 0
   /* A点纵坐标 */
   const yA = 0
   /* x轴偏移量 */
   const offsetX = startPoint[0]
   /* y轴偏移量 */
   const offsetY = startPoint[1]
   /* B点横坐标 */
   const xB = endPoint[0] - offsetX
   /* B纵坐标 */
   const yB = endPoint[1] - offsetY

   /* 根据B点坐标和最大高度h求系数a,b 参数*/
   let b = 0
   let a = 0

   /* 计算系数 a ,b */
   function handerComputer() {
       if (h < 10) {
           a = yB / Math.pow(xB, 2)
       } else {
           /* 因为一般购物车的情况都是向下,实际上我们购物车的坐标系是反向的,所以我们这里要把h 设置成负值 */
           h = -h
           /* 一元二次求解a,b ,现在知道一点  ( xB , yB ) 另外一点 ( maxHx,h )  */
           /* 有效达到最高点时候的x坐标 */
           const effectMaHx = hclientX && Math.abs(hclientX - offsetX) > 0 && Math.abs(hclientX - offsetX) < Math.abs(xB)
           /* 如果hclientX不满足要求,则选A , B 中点为   */
           let maxHx = effectMaHx ? (hclientX - offsetX) : (xB + xA) / 2
           /* 已知两点 求 a , b值  根据解方程式解得 y = ax^2 + bx  */
           a = ((yB / xB) - (h / maxHx)) / (xB - maxHx)
           /* 将 a 带入其中一个求解 b */
           b = (yB - a * Math.pow(xB, 2)) / xB
       }
   }


   /* 轨迹数组 */
   const travelList = []
   /* x 均等分 */
   const averageX = (xB - xA) / point

   /* 处理直线运动 */
   function handerLinearMotion(type) {
       if (type === 'X') {
           const averageY = (yB - yA) / point
           for (let i = 1; i <= point; i++) {
               travelList.push([offsetX, i * averageY + offsetY])
           }
       } else {
           for (let i = 1; i <= point; i++) {
               travelList.push([offsetX + i * averageX, offsetY])
           }
       }
       return travelList
   }

   /* 当 xB的绝对值小于10的情况,我们看作Y轴直线运功    */
   if (Math.abs(xB) < 10) {
       return handerLinearMotion('X')
   }
   /*当 yB的绝对值小于10的情况,我们看作x轴直线运功  */
   if (Math.abs(yB) < 10) {
       return handerLinearMotion('Y')
   }

   handerComputer()
   /* 绘制路径 */
   for (let i = 1; i <= point; i++) {
       const currentX = averageX * i
       const currentY = Math.pow(currentX, 2) * a + b * currentX - yA
       travelList.push([currentX + offsetX, currentY + offsetY])
   }

   return travelList
}

export default flycart

效果

html5小程序飞入购物车(抛物线绘制运动轨迹点)

小程序h5飞入购物车组件?

这里可以把这个方案和组件联系到一起,于是乎飞入购物车组件就搞定了,这里大家要记住的点

1此方案得到的是抛物线各点的left,top值,我们只需要定时改变飞入购物车的图片的left值 ,top就可以 2可以通过计数器功能来改变缩放比,说白了就是改变图片transform:scale值 3不要忘记给图片加上fixed固定定位哦:smile::smile::smile: 主要demo方法(仅供参考)

startCart(){
    /* 开启购物车 */
    /* this.start 储存起始点 clientY clientY  ,this.end储存最终点 clientX clientY*/
    this.start = {}
    this.start['x'] = this.data.current['x']
    this.start['y'] = this.data.current['y']
    const travelList = flycart([ this.start['x'] , this.start['y'] ] ,[ this.end['x'] , this.end['y'] ],25,50 )
    this.startAnimate(travelList)
        },
 startAnimate(travelList) {
    let index = 0
    this.setData({
        cartHidden: false,
        bus_x: this.start['x'],
        bus_y: this.start['y']
    })
    if(travelList.length===0) return
    this.timer = setInterval( ()=> {
        index++
        const currentPoint = travelList.shift()
        this.setData({
            bus_x: currentPoint[0],
            bus_y: currentPoint[1],
            scale: 1 - index / 25
        })
        if (travelList.length === 0) {
            clearInterval(this.timer)
            this.triggerEvent('close')
        }
    }, 33)
}

这里只做了 原生小程序飞入购物车组件 ,h5大致差别不大。

git地址如下

代码地址https://github.com/AlienZhaolin/flycart

到此这篇关于html5小程序飞入购物车(抛物线绘制运动轨迹点)的文章就介绍到这了,更多相关html5飞入购物车内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
发现两个有趣的CSS3动画效果
Aug 14 HTML / CSS
用CSS3来实现社交分享按钮
Nov 11 HTML / CSS
CSS3实现超酷的黑猫警长首页
Apr 26 HTML / CSS
CSS3让登陆面板3D旋转起来
May 03 HTML / CSS
CSS3实现伪类hover离开时平滑过渡效果示例
Aug 10 HTML / CSS
浅谈CSS3中display属性的Flex布局的方法
Aug 14 HTML / CSS
CSS3实现菜单悬停效果
Nov 17 HTML / CSS
用HTML5实现鼠标滚轮事件放大缩小图片的功能
Jun 25 HTML / CSS
使用HTML5进行SVG矢量图形绘制的入门教程
Feb 19 HTML / CSS
使用canvas压缩图片上传的方法示例
Feb 07 HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
Feb 03 HTML / CSS
CSS实现fullpage.js全屏滚动效果的示例代码
Mar 24 HTML / CSS
app内嵌H5 webview 本地缓存问题的解决
Oct 19 #HTML / CSS
使用HTML5做的导航条详细步骤
Oct 19 #HTML / CSS
利用Node实现HTML5离线存储的方法
Oct 16 #HTML / CSS
HTML+CSS+JavaScript实现图片3D展览的示例代码
Oct 12 #HTML / CSS
HTML5逐步分析实现拖放功能的方法
Sep 30 #HTML / CSS
移动端HTML5 input常见问题(小结)
Sep 28 #HTML / CSS
HTML5超文本标记语言的实现方法
Sep 24 #HTML / CSS
You might like
2020年4月放送!《Princess Connect Re:Dive》制作组 & 角色声优公开!
2020/03/06 日漫
php strlen mb_strlen计算中英文混排字符串长度
2009/07/10 PHP
php中将网址转换为超链接的函数
2011/09/02 PHP
浅析PHP 按位与或 (^ 、&amp;)
2013/06/21 PHP
解析PHPExcel使用的常用说明以及把PHPExcel整合进CI框架的介绍
2013/06/24 PHP
PHP实现今天是星期几的几种写法
2013/09/26 PHP
递归删除一个节点以及该节点下的所有节点示例
2014/03/19 PHP
50个PHP程序性能优化的方法
2014/06/02 PHP
JavaScript 数组循环引起的思考
2010/01/01 Javascript
学习JavaScript的最佳方法分享
2011/10/21 Javascript
为JavaScript类型增加方法的实现代码(增加功能)
2011/12/29 Javascript
Bootstrap导航栏各元素操作方法(表单、按钮、文本)
2015/12/28 Javascript
超全面的vue.js使用总结
2017/02/12 Javascript
使用Xcache缓存器加速PHP网站的配置方法
2017/04/22 Javascript
jQuery操作css样式
2017/05/15 jQuery
浅谈React和Redux的连接react-redux
2017/12/04 Javascript
基于D3.js实现时钟效果
2018/07/17 Javascript
Vue Autocomplete 自动完成功能简单示例
2019/05/25 Javascript
24个ES6方法解决JS实际开发问题(小结)
2020/05/31 Javascript
keep-alive保持组件状态的方法
2020/12/02 Javascript
[50:44]DOTA2-DPC中国联赛 正赛 SAG vs Dragon BO3 第二场 2月22日
2021/03/11 DOTA
python实现可以断点续传和并发的ftp程序
2016/09/13 Python
numpy添加新的维度:newaxis的方法
2018/08/02 Python
Python如何实现FTP功能
2020/05/28 Python
python爬虫中PhantomJS加载页面的实例方法
2020/11/12 Python
如何利用CSS3制作3D效果文字具体实现样式
2013/05/02 HTML / CSS
Hertz荷兰:荷兰和全球租车
2018/01/07 全球购物
Banana Republic英国官网:香蕉共和国,GAP集团旗下偏贵族风
2018/04/24 全球购物
香港彩色隐形眼镜在线商店:Stunninglens(全球免费送货)
2019/05/10 全球购物
英国景点门票网站:attractiontix
2019/08/27 全球购物
党的群众路线教育实践活动领导班子整改措施
2014/10/28 职场文书
基于Java的MathML转图片的方法(示例代码)
2021/06/23 Java/Android
海贼王十大潜力果实,路飞仅排第十,第一可毁世界(震震果实)
2022/03/18 日漫
简单聊聊TypeScript只读修饰符
2022/04/06 Javascript
PostgreSQL数据库创建并使用视图以及子查询
2022/04/11 PostgreSQL
LeetCode189轮转数组python示例
2022/08/05 Python