我想知道是否可以将按钮上的图像和使用可绘制的源以及上面的文本结合起来?
我目前正在使用它作为drawable / red_btn.xml中的按钮样式
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" >
<shape>
<solid
android:color="#ef4444" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners
android:radius="3dp" />
<padding
android:left="10dp"
android:top="10dp"
android:right="10dp"
android:bottom="10dp" />
</shape>
</item>
<item>
<shape>
<gradient
android:startColor="#ef4444"
android:endColor="#992f2f"
android:angle="270" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners
android:radius="3dp" />
<padding
android:left="10dp"
android:top="10dp"
android:right="10dp"
android:bottom="10dp" />
</shape>
</item>
</selector>
然后我的按钮
<Button
android:id="@+id/testButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="Income"
android:textSize="15dip"
android:background="@drawable/red_btn"
android:textColor="#fff"
android:textStyle="bold" />
看起来像这样
现在我想在此按钮上方添加另一个.png图像(arrow.png),就像这样
这是可能的,如果,我该怎么办?
提前致谢。 的 __________________________________________________________________________________________________________________________________________
修改
按照下面的 Luksprog的建议后,我现在在drawable中有“red_btn_normal.xml”
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" >
<shape>
<solid
android:color="#ef4444" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners
android:radius="3dp" />
<padding
android:left="10dp"
android:top="10dp"
android:right="10dp"
android:bottom="10dp" />
</shape>
</item>
<item>
<shape>
<gradient
android:startColor="#ef4444"
android:endColor="#992f2f"
android:angle="270" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners
android:radius="3dp" />
<padding
android:left="10dp"
android:top="10dp"
android:right="10dp"
android:bottom="10dp" />
</shape>
</item>
</selector>
和 red_btn_pressed.xml
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:state_pressed="true">
<shape>
<solid android:color="#ef4444" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners android:radius="3dp" />
<padding
android:bottom="10dp"
android:left="10dp"
android:right="10dp"
android:top="10dp" />
</shape>
</item>
<item>
<bitmap
android:gravity="right"
android:src="@drawable/arrow" />
</item>
</layer-list>
然后我创建我的按钮,如“red_btn.xml”
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/red_btn_pressed" android:state_pressed="true"></item>
<item android:drawable="@drawable/red_btn_normal"></item>
</selector>
最后我的按钮
<Button
android:id="@+id/testButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="Income"
android:textSize="15dip"
android:background="@drawable/red_btn"
android:textColor="#fff"
android:textStyle="bold" />
问题是当我点击按钮时它只显示白色箭头,当未按下时它不会显示。代码有什么问题? =)
答案 0 :(得分:12)
我想知道它是否有可能将两个图像组合在一起 按钮并使用可绘制的源并在其上方显示文本?
是的,这是可能的。您的选择器将变为:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/red_btn_pressed" android:state_pressed="true"></item>
<item android:drawable="@drawable/red_btn_normal"></item>
</selector>
其中两个drawable是两个layer-list
drawables,第一个项目是初始选择器中的项目,第二个是.png
图像包装为位图drawbale。例如,对于red_btn_pressed.xml
,您将拥有:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item>
<shape>
<solid android:color="#ef4444" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners android:radius="3dp" />
<padding
android:bottom="10dp"
android:left="10dp"
android:right="10dp"
android:top="10dp" />
</shape>
</item>
<item>
<bitmap
android:gravity="right"
android:src="@drawable/arrow" />
</item>
</layer-list>
而red_btn_normal.xml
将是:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item>
<shape>
<gradient
android:angle="270"
android:endColor="#992f2f"
android:startColor="#ef4444" />
<stroke
android:width="1dp"
android:color="#992f2f" />
<corners android:radius="3dp" />
<padding
android:bottom="10dp"
android:left="10dp"
android:right="10dp"
android:top="10dp" />
</shape>
</item>
<item>
<bitmap android:src="@drawable/allowed" android:gravity="right"/>
</item>
</layer-list>
请注意,如果Button
的尺寸允许,箭头图像将位于 文本的右侧(作为Button
的一部分) s背景)。如果您试图在Button
的文本和该箭头图像之间强加某种定位关系,那么您需要扩展Button
类并自行完成。
答案 1 :(得分:3)
我选择了简单的
<Button
android:id="@+id/testButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="Income"
android:textSize="15dip"
android:background="@drawable/red_btn"
android:drawableRight="@drawable/arrow"
android:textColor="#fff"
android:textStyle="bold" />