通过CSS3 transform实现图片浏览的几种效果

html-css023

通过CSS3 transform实现图片浏览的几种效果,第1张

通过css3和DOM操作,可以实现多种图片浏览的效果 但是大致思路都是一致的:

1)通过DOM操作循环创建出来一组元素

    document.createElement('标签名');

    父级.appendChild('obj')

2)给每一个创建出来的元素添加transform变换效果

    obj.style.transform=' rotateX(30deg)'

    obj.style.transition='1s all ease'

3)当变换结束的时候,瞬间拉回变换并换底图

    obj.addEventListener('transitionend',function(){},false}

    obj.style.transform=' rotateX(0deg)'

    obj.style.transition='none'

  当前要显示的一面:url("img/'+iNow%3+'.jpg");

  即将要显示的一面:url("img/'+(iNow+1)%3+'.jpg");

4)对用户一些影响当前变换的操作进行约束

分散效果重点:

每一个小块的transform:translate('+(aSpan[i].offsetLeft-oBox.offsetWidth/2)+'px,'+(aSpan[i].offsetTop -oBox.offsetHeight/2)+'px) rotateX('+rnd(-180,180)+'deg) rotateY('+rnd(-180,180)+'deg) scale(1.4)

每个小块的transform: aSpan[i].style.transform='perspective(800px) rotateY(-180deg)'

transition: aSpan[i].style.transition='500ms all ease '+(aSpan[i].c+aSpan[i].r)*200+'ms'

第四个参数代表等待运动的时间,故生成依次轮流翻转的效果

document.onmouseover=function(){

当前那个元素的transform:rotateZ(90deg)

}

依次出现的效果:

oBj.style.transform ='rotateY('+i*360/N+'deg) translateZ(300px)'

布局如下:

<div id="box">

    <div id="page">

        <div class="front"></div>

        <div class="back"></div>

    </div>

    <div id="page2"></div>

</div>

#page是当前的图片 ,#page2是将要变换的图片,其中#page的front背景图片和#box的背景图片拼成一张当前显示的图片,#page的back背景图片和#page2的背景图片拼成一张即将要换的图片

这是一个数学问题。

当盒子模型和图片比例不一致时,要保持比例显示会出现两种情况:

一种是覆盖裁剪background-size: cover,即以短边为标准,图片缩放铺满整个容器的宽高,多出来的部分会裁剪掉;

另一种是完整包含background-size: contain,即以长边为标准,图片缩放完全展示在容器的内部,不足的部分会填充空白。

当盒子模型和图片比例不一致时,不保持比例显示可对图片进行拉伸以铺满整个容器的宽高background-size: 100% 100%;或对高进行拉伸background-size: auto 100%或对宽进行拉伸background-size: 100% auto ;或设置固定数值background-size: 20px 30px 。