在android中以编程方式更改布局的背景颜色

时间:2013-03-25 13:54:08

标签: android android-layout android-linearlayout

我必须开发一个Android应用程序。

我必须显示正常状态的背景颜色是#424340。但我必须单击这些布局(选择并按下状态)意味着必须更改背景颜色是#FF0000。我可以如何编程...请给我这些解决方案...

我使用下面的代码以编程方式创建布局:

LinearLayout ar = new LinearLayout(this);
            ar.setOrientation(LinearLayout.VERTICAL);
            ar.setPadding(3, 3, 3, 3);

            ar.setLayoutParams(artiLayoutParams);
            ar.setGravity(Gravity.CENTER); 
            ar.setBackgroundDrawable(getResources().getDrawable(R.drawable.list_selector));

这里我点击这些布局意味着更改背景颜色。所以我使用下面的代码。请检查它。

list_selector.xml:

<?xml version="1.0" encoding="utf-8"?>
 <selector xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- Selector style for listrow -->
 <item 

 android:state_selected="false"
 android:state_pressed="false" 
android:state_focused="false"
android:drawable="@drawable/gradient_bg" />
<item android:state_pressed="true"
android:state_selected="true" 
android:state_focused="true"
android:drawable="@drawable/gradient_bg_hover" />
 </selector>

gradient_bg.xml:

    <?xml version="1.0" encoding="utf-8"?>



  <shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
        <stroke android:width="3dp" android:color="#424340" />

        <padding android:left="3dp" android:top="3dp" android:right="3dp"
            android:bottom="3dp" />
        <corners android:radius="4dp" />
    </shape>

gradient_bg_hover.xml:

    <?xml version="1.0" encoding="utf-8"?>

  <shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

        <stroke android:width="3dp" android:color="#FF0000" />
         <padding android:left="3dp" android:top="3dp" android:right="3dp"
            android:bottom="3dp" />

        <corners android:radius="4dp" />
        </shape> 

但是我的背景颜色没有改变。我的代码中有什么问题。请帮助我......

1 个答案:

答案 0 :(得分:0)

你的州似乎错了。你可以试试这个来确认它是否有效吗?

<?xml version="1.0" encoding="utf-8"?>
 <selector xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- Selector style for listrow -->
 <item 
 android:state_pressed="false"
android:drawable="@drawable/gradient_bg" />
<item android:state_pressed="true"
android:drawable="@drawable/gradient_bg_hover" />
 </selector>