首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过使用-webkit-transform而不是-webkit-transition来利用硬件加速?

通过使用-webkit-transform而不是-webkit-transition来利用硬件加速?
EN

Stack Overflow用户
提问于 2012-01-05 04:16:52
回答 2查看 1.6K关注 0票数 1

我希望创建一个动画,在此动画中,每次单击按钮时,对象都会向其右侧移动一定量。

例如,如果对象的初始位置是“左:10px”,并且每1个动画循环将其移动10px,那么在第一次单击之后,它应该是20px,在第二次单击之后,它应该是30px,依此类推。

下面是我现在的代码:

JavaScript

代码语言:javascript
复制
document.getElementById( 'move-me' ).addEventListener( 'click', function () {

    var move = document.getElementById( 'move' );
    move.style.left = ( move.offsetLeft + 10 ) + 'px';

}, false );

HTML

代码语言:javascript
复制
<button id="move-me">Move</button>
<div id="move"></div>

CSS

代码语言:javascript
复制
#move {
    background: green;
    height: 50px;
    left: 0px;
    position: absolute;
    top: 100px;
    transition:             left 250ms ease-in-out;
        -moz-transition:    left 250ms ease-in-out;
        -ms-transition:     left 250ms ease-in-out;
        -o-transition:      left 250ms ease-in-out;
        -webkit-transition: left 250ms ease-in-out;
    width: 50px;
}

这段代码使用了CSS3转换,但它没有使用我的安卓设备上的-webkit-transform硬件加速。我该怎么解决这个问题呢?

EN

回答 2

Stack Overflow用户

发布于 2012-01-05 05:33:40

选择不是在-webkit-transform-webkit-transition之间,而是在left-webkit-transform之间。

下面是如何使用3d加速的方法:

代码语言:javascript
复制
#move {
    background: green;
    height: 50px;
    left: 0px;
    position: absolute;
    top: 100px;
    -moz-transition:    -moz-transform 250ms ease-in-out;
    -ms-transition:     -ms-transform 250ms ease-in-out;
    -o-transition:      -o-transform 250ms ease-in-out;
    -webkit-transition: -webkit-transform 250ms ease-in-out;
    transition:             transform 250ms ease-in-out;
    width: 50px;
}

Javascript:

代码语言:javascript
复制
document.getElementById( 'move' ).addEventListener( 'click', function() {
    var move = document.getElementById( 'move' );
    var transform = "translate3d("+ (move.offsetLeft+200) + "px, 0, 0)";
    move.style.webkitTransform = transform;
    move.style.mozTransform = transform;
    move.style.msTransform = transform;
    move.style.oTransform = transform;
    move.style.transform = transform;

}, false );

http://jsfiddle.net/CjQ8H/

票数 0
EN

Stack Overflow用户

发布于 2012-04-24 16:30:17

您也可以使用translateX。这绝对是硬件加速。

代码语言:javascript
复制
targetDiv.style.webkitTransition = "0ms"

targetDiv.style.webkitTransform = "translateX(100%)

这会将div向右移动100%,但只有在硬件加速设备中才会很好和平滑。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8733406

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档