自定义视图仅显示一次

时间:2011-07-01 18:54:37

标签: android android-linearlayout custom-view

我制作了一个非常简单的customView,一个灰色矩形,矩形内部以百分比标记任意数量的红色标记。

public class DemoView extends View {
private ShapeDrawable mDrawable;
private ArrayList<ShapeDrawable> mMarks;

public DemoView(Context context, int[] marks) {
    super(context);
    int x = 0;
    int y = 0;
    int width = 100;
    int height = 10;
    // Timeline Initially empty

    mDrawable = new ShapeDrawable(new RectShape());
    mDrawable.getPaint().setColor(Color.GRAY);
    mDrawable.setBounds(x, y, x + width, y + height);
    // Add marks
    if (marks != null && marks.length % 2 == 0) {
        mMarks = new ArrayList<ShapeDrawable>(marks.length / 2);
        ShapeDrawable mark;
        for (int i = 1; i < marks.length; i = i + 2) {
            mark = new ShapeDrawable(new RectShape());
            mark.getPaint().setColor(Color.RED);
            mark.setBounds(x + marks[i - 1], y, x + marks[i], y + height);
            mMarks.add(mark);
        }
    }
}

@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    mDrawable.draw(canvas);
    if (mMarks != null)
        for (ShapeDrawable mark : mMarks)
            mark.draw(canvas);
}

}

但是我无法弄清楚如何使用视图。每次我尝试在linearlayout或relativelayout中添加多个视图时,我只会看到其中一个视图。

XML:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/llayout"
>
<TextView  
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:text="@string/hello"
/>
</LinearLayout>

布局代码:

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    LinearLayout ll = (LinearLayout) findViewById(R.id.llayout);
    demoview = new DemoView(this, new int[]{10,15,35,60});
    demoview.setId(ID_NUM++);
    ll.addView(demoview);
    demoview2 = new DemoView(this, new int[]{0,1,3,6});
    demoview2.setId(ID_NUM++);
    ll.addView(demoview2);
    demoview3 = new DemoView(this, new int[]{25,60});
    demoview3.setId(ID_NUM++);
    ll.addView(demoview3);
    demoview4 = new DemoView(this, new int[]{15,60});
    demoview4.setId(ID_NUM++);
    ll.addView(demoview4);

}

结果:

Result of linearlayout code above..

这是错误的路线吗?我错过了多次使用此视图的明显关键吗?如果这不是正确的路线,还有其他方法来制作自定义形状吗?也许扩展rectShape?

2 个答案:

答案 0 :(得分:1)

您可能需要观看this

Romain解释了如何在那里进行自定义视图。

答案 1 :(得分:1)

根据Mibollma的建议,我观看了上面的视频,这是来自Google I / O 2009的关于加快用户界面的视频。

两年后,这些信息绝对适用。通过使用ViewHolder,我不仅能够加速我的所有ListView,我还能找到问题的答案。

创建自定义视图时,必须覆盖两个方法,第一个方法在上面列出:onDraw。

缺少方法? onMeasure()。可以找到更多信息here.