翻译的按钮没有给出正确的结果

时间:2013-02-05 18:31:41

标签: android animation button onclick

我在我的活动中有一个按钮,并使用TranslateAnimation来改变它的位置。

我正在使用anim.setFillAfter(true);为了保持最终的平移,按钮会改变其位置,但触摸区域保持不变。
现在,当我触摸按钮时,它不起作用,而是触摸按钮的先前位置,调用它的监听器。

这是我的代码:
MainActivity.java

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Animation anim=new TranslateAnimation(0, 100, 0, 0);
        anim.setDuration(500);
        anim.setFillAfter(true);
        Button mybtn = (Button)findViewById(R.id.btn);
        mybtn.startAnimation(anim);
    }

    public void myFunc(View v){
        Toast.makeText(this, "btn clicked", Toast.LENGTH_SHORT).show();
    }
}

activity_main.xml中

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:tools="http://schemas.android.com/tools"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            tools:context=".MainActivity" >

            <Button
                android:id="@+id/btn"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:layout_centerVertical="true"
                android:text="@string/hello_world" 
                android:onClick="myFunc"/>

        </RelativeLayout>

2 个答案:

答案 0 :(得分:1)

我在此页面找到了我的查询答案 vogellahere android解释了它,按钮需要属性动画而不仅仅是视图动画:

以下是我使用的代码:

Button mybtn = (Button)findViewById(R.id.btn);
mybtn.animate().translationX(400).setDuration(500);

Thanx为你提供帮助...... 如果其他人需要帮助,我将离开这篇文章。

答案 1 :(得分:0)

我重新生成了您的案例,似乎只有50%的按钮显示所选颜色。是对的吗 ?试试这个:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Button sampleButton = (Button)findViewById(R.id.btn);
    sampleButton.animate().translationX(somevalue).setDuration(someduration);
}