0

動的に変化するデータ行で 4 列を実行したいと考えています。私は LinearLayout でこれを行いますが、4x10 セットのテキストビューを取得する良い方法が見つかりません。この .java は、下部にリストされている致命的なエラーを引き起こしています。

public class DebtList extends Activity {

Integer trigger = 5;
Double totalDebt = 0.00;

@TargetApi(Build.VERSION_CODES.HONEYCOMB)
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.debtlist);

    //Bundle extras = getIntent().getExtras();

    String[] debtNames = new String[10];
    Double[] debtAmount = new Double[10];
    Double[] debtRate = new Double[10];
    Double[] debtTerm = new Double[10];

    Integer stopper = trigger+1;

    TableLayout tl=(TableLayout)findViewById(R.id.debtlist);
    TableRow tr1 = new TableRow(this);
    TextView textview = new TextView(this);

    for(int i=0; i<stopper; i++)
    {

        tr1.setLayoutParams(new LayoutParams( LayoutParams.FILL_PARENT,LayoutParams.WRAP_CONTENT));
        tr1.setId(i);

        textview.setText("" + i);
        tr1.addView(textview);
        tl.addView(tr1, new TableLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT));

        tr1.setLayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT));
        tr1.setId(i);

    }

    trigger++;
}
}

私は(基本的に)空の.XMLを使用しています:

<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/debtlist"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

</TableLayout>

私のLogCat:

10-13 04:12:07.412: E/AndroidRuntime(799): FATAL EXCEPTION: main
10-13 04:12:07.412: E/AndroidRuntime(799): java.lang.ClassCastException: android.app.ActionBar$LayoutParams cannot be cast to android.widget.LinearLayout$LayoutParams
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.LinearLayout.measureVertical(LinearLayout.java:587)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.TableLayout.measureVertical(TableLayout.java:468)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.TableLayout.onMeasure(TableLayout.java:431)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.View.measure(View.java:10828)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4351)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.View.measure(View.java:10828)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.LinearLayout.measureVertical(LinearLayout.java:764)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.LinearLayout.onMeasure(LinearLayout.java:519)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.View.measure(View.java:10828)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4351)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:267)
10-13 04:12:07.412: E/AndroidRuntime(799):  at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:1890)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.View.measure(View.java:10828)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.ViewRoot.performTraversals(ViewRoot.java:909)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.view.ViewRoot.handleMessage(ViewRoot.java:2003)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.os.Handler.dispatchMessage(Handler.java:99)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.os.Looper.loop(Looper.java:132)
10-13 04:12:07.412: E/AndroidRuntime(799):  at android.app.ActivityThread.main(ActivityThread.java:4025)
10-13 04:12:07.412: E/AndroidRuntime(799):  at java.lang.reflect.Method.invokeNative(Native Method)
10-13 04:12:07.412: E/AndroidRuntime(799):  at java.lang.reflect.Method.invoke(Method.java:491)
10-13 04:12:07.412: E/AndroidRuntime(799):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
10-13 04:12:07.412: E/AndroidRuntime(799):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
10-13 04:12:07.412: E/AndroidRuntime(799):  at dalvik.system.NativeStart.main(Native Method)

ユーザーが入力したデータ量に基づいて 4X1-10 の TextView セットを表示するためのより効率的な方法がある場合は、お知らせください。

また、APIレベル12を使用しています

4

2 に答える 2

1

ログのように:

ClassCastException: android.app.ActionBar$LayoutParams は android.widget.LinearLayout$LayoutParams にキャストできません

ActionBar.LayoutParamsLayoutParams を TableLayout および Buttons に設定するためにインポートしていることを意味するため、LinearLayout.LayoutParams を次のように使用します。

for(int i=0; i<stopper; i++)
    {

     tr1.setLayoutParams(new LinearLayout.LayoutParams( LayoutParams.FILL_PARENT,
                                                     LayoutParams.WRAP_CONTENT));
        //.....
     tr1.setLayoutParams(new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT,
                                                    LayoutParams.WRAP_CONTENT)));
     tr1.setId(i);

    }
于 2013-10-13T04:19:57.007 に答える
0

テーブル レイアウトを使用していて、ActionBar Linear Layout のコンテキストを拡張しているため、クラス キャスト例外が発生しています。

java.lang.ClassCastException: android.app.ActionBar$LayoutParams は android.widget.LinearLayout$LayoutParams にキャストできません

x行数に対して行ごとに4列の方法はありますか?

これにはカスタム レイアウトを使用し、それを使用します。

 for(int i=0; i<stopper; i++)
    {

       // Inflate your row "template" and fill out the fields.
    TableRow row = (TableRow)LayoutInflater.from(context).inflate(R.layout.attrib_row,  null);
    ((TextView)row.findViewById(R.id.attrib_name)).setText(b.NAME);
    ((TextView)row.findViewById(R.id.attrib_value)).setText(b.VALUE);
    table.addView(row);

    }
于 2013-10-13T04:32:37.537 に答える