2

私の活動では、上部にいくつかのテキストビューを表示し、その下にリストビューを膨らませたいと考えています。addview() などのさまざまな方法を試みましたが、うまくいきませんでした。膨張したビューがメイン レイアウトになります。

どんな助けでも大歓迎です。Ted Hopp ソリューションに基づく LogCat エラー

10-20 02:38:38.322: D/AndroidRuntime(1253): VM をシャットダウンしています 10-20 02:38:38.322: W/dalvikvm(1253): threadid=3: キャッチされない例外で終了するスレッド (group=0x4001b188) 10 -20 02:38:38.322: E/AndroidRuntime(1253): キャッチされていないハンドラー: キャッチされていない例外が原因でスレッド メインが終了します 10-20 02:38:38.342: E/AndroidRuntime(1253): java.lang.RuntimeException: 起動できませんactivity ComponentInfo{com.example.mycoursetimetable/com.example.mycoursetimetable.MyCourses}: java.lang.IllegalStateException: リストにヘッダー ビューを追加できません -- setAdapter は既に呼び出されています。10-20 02:38:38.342: E/AndroidRuntime(1253): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496) で 10-20 02:38:38.342: E/AndroidRuntime(1253): Android で。 app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512) 10-20 02:38:38.342: E/AndroidRuntime(1253): E/AndroidRuntime(1253): com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 10-20 02:38:38.342: E/AndroidRuntime(1253): dalvik.system.NativeStart.main で(ネイティブ メソッド) 10-20 02:38:38.342: E/AndroidRuntime(1253): 原因: java.lang.IllegalStateException: リストにヘッダー ビューを追加できません -- setAdapter は既に呼び出されています。10-20 02:38:38.342: E/AndroidRuntime(1253): android.widget.ListView.addHeaderView(ListView.java:256) 10-20 02:38:38.342: E/AndroidRuntime(1253): Android. widget.ListView.addHeaderView(ListView.java:279) 10-20 02:38:38.342: E/AndroidRuntime(1253): com.example.mycoursetimetable.MyCourses.onCreate(MyCourses.java:30) 10-20 02: 38:38.342: E/AndroidRuntime(1253): android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 10-20 02:38:38.342: E/AndroidRuntime(1253): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459) 10-20 02:38:38.342: E/AndroidRuntime(1253): ... 11 より 10-20 02:38:38.382: I/dalvikvm(1253 ): threadid=7: シグナル 3 10-20 02:38:38.382 に反応しています: E/dalvikvm(1253): スタック トレース ファイル '/data/anr/traces.txt' を開けません: 許可が拒否されました 10-20 02: 38:47.463: I/Process(1253): シグナルを送信しています。PID: 1253 SIG: 9

activity_my_courses

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical"
    android:id="@+id/main" >

    <Button
        android:id="@+id/labelAddCourseButton"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:onClick="addCourseButton"
        android:padding="10dp"
        android:text="@string/CourseName" />

</LinearLayout>

リストコース

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/listLayout"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="horizontal" >



    <TextView
        android:id="@+id/labelModuleCode"
        android:layout_height="wrap_content"
         android:layout_width="wrap_content"
         android:layout_marginLeft="10dp"
        android:text="@string/CourseName"
        android:textSize="10dp" />

     <TextView
        android:id="@+id/labelCourseType"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/CourseType"
        android:layout_marginLeft="10dp"
        android:textSize="10dp" />
</LinearLayout>

コード

public class MyCourses extends ListActivity {

    static final String TEST = "com.example.mycoursetimetable.TEST";
    String [] MODULE;

        @Override
        public void onCreate(Bundle savedInstanceState) 
        {
        super.onCreate(savedInstanceState);

        LinearLayout main = (LinearLayout)this.findViewById(R.id.main);
        MODULE = getResources().getStringArray(R.array.module);
        setListAdapter(new ListArrayAdapter(this,MODULE));
        }



        public void addCourseButton (View addCourseButton) 
        {
         Intent intent = new Intent(this,AddCourse.class);
         startActivity(intent);
        }

        protected void onListItemClick(ListView l, View v, int position, long id)
        {
          super.onListItemClick(l, v, position, id);


        try {
            Class test = Class.forName("com.example.MyCourseTimeTable.AddCourse");
            Intent intent = new Intent(MyCourses.this, test);

            TextView textView = (TextView) v.findViewById(R.id.labelModuleCode);
            String module = textView.getText().toString();


            intent.putExtra(TEST,module);
            startActivity(intent);
            }   
                catch (ClassNotFoundException e)
                {
                e.printStackTrace();
                }

        }

}

class ListArrayAdapter extends ArrayAdapter<String> 
{
    //  You only need one copy of LayoutInflater
    private final LayoutInflater inflater;

    //create the ArrayAdpater
    public ListArrayAdapter(Context context, String[] test) 
    {
        super(context, R.layout.activity_my_courses, test);
        inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) 
    {
        ViewHolder holder;
        if(convertView == null) {


            // Inflate the layout that you want for each row


            convertView = inflater.inflate(R.layout.listcourses, parent, false);

            holder = new ViewHolder();
            holder.code = (TextView) convertView.findViewById(R.id.labelModuleCode);
            holder.type = (TextView) convertView.findViewById(R.id.labelCourseType);

            // Add a link for your button as well and define its OnClickListener here to, eventually...

            convertView.setTag(holder);
        }
        else 
            holder = (ViewHolder) convertView.getTag();

        String module = getItem(position);
        //set the text to the string values based on position
        holder.code.setText(module);

        //return the layout
        return convertView;
    }

    class ViewHolder {
        TextView code;
        TextView type;
    }
}
4

2 に答える 2

3

独自のアクティビティ レイアウトを定義しようとするのではなく、次のようなものを使用できます。

public class MyCourses extends ListActivity {

    static final String TEST = "com.example.mycoursetimetable.TEST";
    String [] MODULE;

    @Override
    public void onCreate(Bundle savedInstanceState) 
    {
        super.onCreate(savedInstanceState);

        MODULE = getResources().getStringArray(R.array.module);
        getListView().addHeaderView(getHeader()); // must come before next line
        setListAdapter(new ListArrayAdapter(this,MODULE));
    }

    private View getHeader() {
        LayoutInflater inflater =
            (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE);
        return inflater.inflate(R.layout.listcourses, null);
    }
    . . .
}

layout/listcourses.xmlこれにより、リストのヘッダーで定義されたビューが作成されます。

于 2012-10-31T15:06:45.400 に答える
0

私はあなたの<ListView/>下にテキストビューがandroid:id\list必要だと思いsetContentView(YOUR LAYOUT FILE)ますonCreate()

于 2012-10-31T15:04:34.457 に答える