我想用两种纯色(水平)创建一个矩形来实现这样的效果:
我听说过layer-list
,虽然我可以用它来包含两个颜色不同的矩形,但它似乎只能垂直放置形状。
有没有办法使用 lalyer-list 来实现这一点,还是我应该使用完全不同的东西?我想保持简单,能够在运行时更改形状颜色。
谢谢。
我想用两种纯色(水平)创建一个矩形来实现这样的效果:
我听说过layer-list
,虽然我可以用它来包含两个颜色不同的矩形,但它似乎只能垂直放置形状。
有没有办法使用 lalyer-list 来实现这一点,还是我应该使用完全不同的东西?我想保持简单,能够在运行时更改形状颜色。
谢谢。
这肯定会根据您的要求绘制形状:
根据需要调整大小<item>
!
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:left="50dip">
<shape
xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<solid android:color="#0000FF" />
</shape>
</item>
<item android:right="50dip">
<shape
xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<solid android:color="#ff0000" />
</shape>
</item>
</layer-list>
您可以为此创建自定义可绘制对象。只需扩展 Drawable 类。
这是一个示例代码,它可以绘制您想要的矩形,您可以提供任意数量的颜色。
public class ColorBarDrawable extends Drawable {
private int[] themeColors;
public ColorBarDrawable(int[] themeColors) {
this.themeColors = themeColors;
}
@Override
public void draw(Canvas canvas) {
// get drawable dimensions
Rect bounds = getBounds();
int width = bounds.right - bounds.left;
int height = bounds.bottom - bounds.top;
// draw background gradient
Paint backgroundPaint = new Paint();
int barWidth = width / themeColors.length;
int barWidthRemainder = width % themeColors.length;
for (int i = 0; i < themeColors.length; i++) {
backgroundPaint.setColor(themeColors[i]);
canvas.drawRect(i * barWidth, 0, (i + 1) * barWidth, height, backgroundPaint);
}
// draw remainder, if exists
if (barWidthRemainder > 0) {
canvas.drawRect(themeColors.length * barWidth, 0, themeColors.length * barWidth + barWidthRemainder, height, backgroundPaint);
}
}
@Override
public void setAlpha(int alpha) {
}
@Override
public void setColorFilter(ColorFilter cf) {
}
@Override
public int getOpacity() {
return PixelFormat.OPAQUE;
}
}
这会给你两种颜色一半和一半垂直。将此代码放入drawable
资源中。
<item
android:top="320dip">
<shape
xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<solid android:color="@color/red" />
</shape>
</item>
<item android:bottom="320dip">
<shape
xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >
<solid android:color="@color/yellow" />
</shape>
</item>