手机web图片左右滑动动画效果分享

最近在做一个手机端web站点,里面有一个图片展示效果:


1、点击任意图片时图片全屏展示,左右滑动能展示其他的图片。

2、滑动超过一定范围自动滑到下一张图片,不超过则回退到当前照片位置。此处的滑动要带动画效果


实现:

每张图片外面一个div,将其宽度设置为100%,最外层有一个div[命名为outerDiv],其宽度设为:总图片数量*100+‘%’。给最外层div设置touchstart,touchmove,touchend事件监听处理函数,

在touchmove中根据移动的x轴距离动态改变outerDiv的x轴距离即可实现图片滑动效果,在touchend中根据当前滑动的距离判断滑动到下一张还是回退当前图片位置。

之前我们可以通过设置outerDiv的position属性,然后改变left值实现移动效果,这里我用的是css3的动画函数transform,简单,且可以实现动画效果


transform参数:

-webkit-transform:translate(100px,200px) tr //可以设置x、y轴方向移动距离

-webkit-transform:translateX(100px) translateY(200px)  translateZ(3000px) //可以设置x、y、z轴方向移动距离.3D效果

-webkit-transition:.4s ease;//设置动画时间

定义动画时间:

.transition {
    -webkit-transition:.4s ease;
    -moz-transition:.4s ease;
    -ms-transition:.4s ease;
    -o-transition: .4s ease;
    transition:.4s ease;
}


关键代码:

var touchOption={touchStartX:0,startTranslateX:0,moveDistance:0};

1、touchstart

outerDiv.addEventListener('touchstart',function(){

$(this).removeClass('transition');//移除动画效果,否则移动时图片会颤动

touchOption.touchStartX = e.touches[0].clientX;
                if ($(this).css("-webkit-transform") == 'none') {
                    touchOption.startTranslateX = 0;
                }
                else {
                    //css-webkit-transform属性值格式:matrix(1, 0, 0, 1, -4140, 0)
                    var transfrom_info = $('.sourcePhotoDiv').css("-webkit-transform").split(',')[4];//获取当前outerDiv的x轴坐标
                    touchOption.startTranslateX = parseInt(transfrom_info);
                }

},false);


2、touchmove

outerDiv.addEventListener('touchmove',function(){
             touchOption.moveDistance = (e.touches[0].clientX - touchOption.touchStartX);
                var TranslateX = touchOption.startTranslateX + touchOption.moveDistance;
                $(this).css('-webkit-transform', 'translateX('+ TranslateX +'px) translateZ(0)'); //移动图片

},false);


3、touchend

outerDiv.addEventListener('touchend',function(){

            $(this).addClass('transition);//添加动画效果

             var moveX=100;//此处计算移动移动下一张图片还是退货当前图片代码省略            
                $(this).css('-webkit-transform', 'translateX('+ moveX +'px) translateZ(0)'); //移动图片

},false);


总结:

1、outerDiv的动画参数和效果都是js动态添加的,不需要事先定义

2、用translate(x,y)这种参数时,图片移动时会颤动

3、用translateX() 且带translateZ(0)时图片移动正常,不带translateZ(0)同样出现颤动

4、如果用的是translateX(moveX) ranslateZ(0)这种格式,如果moveX用的是百分比值,如‘50%’,在android手机自动浏览器和uc浏览器中则没有动画效果,用px单位值则正常


为防止图片移动过程颤动和保证动画效果,建议大家用translateX(100px) ranslateZ(0)这种参数,且移动距离用px值



  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值