android上的渐变按钮颜色变化

android上的渐变按钮颜色变化,android,button,background-color,Android,Button,Background Color,我想逐渐改变按钮的颜色,点击后就可以了。例如,我的意思是,按钮必须有下一组颜色:默认情况下-深蓝色,然后是深蓝色,然后是蓝色,然后是浅蓝色,最后是最浅的蓝色。这只是一个例子,我真的想在循环中改变按钮的颜色,就像在下一个代码中一样。但是,我不明白,为什么它不显示中间色。它只显示第一种颜色和最后一种颜色 如何改进这一点 public class ActivityExample extends Activity { private changeColorBtn; @Override protecte

我想逐渐改变按钮的颜色,点击后就可以了。例如,我的意思是,按钮必须有下一组颜色:默认情况下-深蓝色,然后是深蓝色,然后是蓝色,然后是浅蓝色,最后是最浅的蓝色。这只是一个例子,我真的想在循环中改变按钮的颜色,就像在下一个代码中一样。但是,我不明白,为什么它不显示中间色。它只显示第一种颜色和最后一种颜色

如何改进这一点

public class ActivityExample extends Activity {
private changeColorBtn;

@Override
protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_animations);

    changeColorBtn = (Button) findViewById(R.id.btn_change_color);

    changeColorBtn.setBackgroundColor(Color.BLACK);
    changeColorBtn.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            changeButtonColor(v);

        }
    });

}

private void changeButtonColor(View v) {
    // How many intermediate color will be, and delay in millisecond between them
    int count = 20, delay = 100;
    for (int i = 0; i < count; i++) {
        try {

            int color = ((ColorDrawable) changeColorBtn.getBackground())
                    .getColor();
            int blue = Color.blue(color), red = Color.red(color), green = Color.green(color);
            changeColorBtn.setBackgroundColor(Color.rgb(red+10, green+5, blue+3));

            Thread.sleep(delay);
        } catch (InterruptedException inE) {
        }
    }

}

@Override
protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}
公共类活动示例扩展活动{
私人电话号码;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u动画);
changeColorBtn=(按钮)findViewById(R.id.btn\u change\u color);
changeColorBtn.setBackgroundColor(颜色:黑色);
changeColorBtn.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
变换按钮颜色(v);
}
});
}
私有void changeButtonColor(视图五){
//中间色的数量,以及它们之间的延迟(毫秒)
整数计数=20,延迟=100;
for(int i=0;i

}

我使用解决了这个问题。您可以执行下一步:

  • 在drawable文件夹中创建一个xml文件,并在其中写入如下内容:
`

`

并将此xml文件保存在/res/values/文件夹中,将xml命名为color.xml

  • 并启动代码转换:
`

`


这对我很有帮助,我希望它对其他人有用。

我猜在执行循环时视图没有被重新绘制。我建议使用动画类。您可以尝试请求在当前循环中重新绘制视图,但它不会像动画那样平滑或一致。您的最低android版本是什么?请注意:您正在UI线程上调用
Thread.sleep()
,这将导致您的应用程序延迟…我有minSdkVersion=“13”
<?xml version="1.0" encoding="UTF-8"?>
<transition xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@color/color1" />
    <item android:drawable="@color/color2" />
</transition>
<?xml version="1.0" encoding="UTF-8"?>
<resources>
    <color name="color1">#990000</color>
    <color name="color2">#cc3311</color>
</resources>
int durationMillis = 2000;
TransitionDrawable transition = (TransitionDrawable) changeColorBtn.getBackground();
transition.startTransition(durationMillis);