从xml创建自定义视图

时间:2012-02-25 18:40:39

标签: java android xml view

我想做一个来自XML的自定义视图。

这是我的XML:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >
    <TextView 
        android:id="@+id/movieTitle"
        android:text="@string/movietitle"
        android:textSize="35dp"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        />
    <com.galite.headliner.views.LoaderImageView
        android:id="@+id/moviePoster" 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@id/movieTitle"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="20dp"
        android:layout_marginBottom="20dp"
        android:contentDescription="@string/poster"
        />
    <TextView
        android:id="@+id/movieDescription"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/description"
        android:layout_below="@id/moviePoster"
        android:gravity="center"
        />
</RelativeLayout>

我想要扩展到自定义视图,因为我需要使用像onClick和所有内容的方法。

这是我的构造函数:

public MyView(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
    this.context = context;
    initializeView();
}

public void initializeView(){
    inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    v = inflater.inflate(R.layout.movie, null);
}

如何让MyView等于v?

1 个答案:

答案 0 :(得分:2)

您必须将膨胀的视图v附加到MyView,如下所示:

v = inflater.inflate(R.layout.movie, this, true);

如果你想要那个确切的布局,那么让MyView扩展RelativeLayout并像这样修改xml布局:

<merge xmlns:android="http://schemas.android.com/apk/res/android" >
    <TextView 
        android:id="@+id/movieTitle"
        android:text="@string/movietitle"
        android:textSize="35dp"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        />
    <com.galite.headliner.views.LoaderImageView
        android:id="@+id/moviePoster" 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@id/movieTitle"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="20dp"
        android:layout_marginBottom="20dp"
        android:contentDescription="@string/poster"
        />
    <TextView
        android:id="@+id/movieDescription"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/description"
        android:layout_below="@id/moviePoster"
        android:gravity="center"
        />
</merge>