0

RelativeLayout実行時に一連の画像を別の画像の下に追加しようとしていますTextView。これまでのところ、部分的に正しく表示されていますが、正確には正しく表示されていません。それらを別の行に移動させることはできません。誰かが私に手を差し伸べて、正しい道を教えてくれることを願っています。一連の画像がこの下に表示されますTextView( R.id.date):

     TextView date = (TextView) findViewById(R.id.date);

    //// image view start //////
    int photos = Integer.parseInt(total_photo);
    RelativeLayout mainLayout = (RelativeLayout) findViewById(R.id.relative_layout_b);
    for (int i = 0; i < limit; i++){
        final ImageView imageView = new ImageView (this);
        imageView.setId(i);
        imageView.setImageResource(R.drawable.photo_frame);
        RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT);
        imageView.setPadding(10, 10, 0, 0);
        imageView.setAdjustViewBounds(true);
        imageView.setMaxHeight(80);
        imageView.setMaxWidth(80);
        lp.addRule(RelativeLayout.BELOW, R.id.date);
        lp.addRule(RelativeLayout.RIGHT_OF, imageView.getId() - 1);
        imageView.setLayoutParams(lp);
        mainLayout.addView(imageView);
    }

現在、写真の総数 - 1 のみが表示されます (つまり、5 枚ある場合は 4 枚のみが表示されます)。各行に5を表示させたいのですが、6、11、16などに達するとすぐに次の行に移動します。このレイアウトは、かなりの数のビューがあるため、 aScrollViewと a内にネストされています。RelativeLayoutだから、私はこれに固執する必要がありRelativeLayoutます。

4

1 に答える 1

1

あなたが何をしようとしているのか理解できたら、以下のコードImageViewsがあなたが望むように配置されているかどうかを確認してください (どれだけ効率的かわかりません):

    private static final int ROW_ITEMS = 5; // 5 ImageViews per row

    // ...
    RelativeLayout mainLayout = (RelativeLayout) findViewById(R.id.relative_layout_b);
            int limit = 13; // I assume that limit is the number of ImageView that you'll put in the layout
            int rows = limit / ROW_ITEMS; // the number of rows that results from limit
            int leftOver = limit % ROW_ITEMS; // see if we have incomplete rows
            if (leftOver != 0) {
                rows += 1;
            }
            int id = 1000; // the ids of the ImageViews 1000, 1001, 1002 etc
            int belowId = R.id.date; // this id will be used to position the ImageView on another row
            while (rows > 0) {
                int realItemsPerRow = ROW_ITEMS;
                if (leftOver != 0 & rows == 1) {
                    realItemsPerRow = Math.min(ROW_ITEMS, leftOver);
                }           
                for (int i = 0; i < realItemsPerRow; i++) {
                    final ImageView imageView = new ImageView(this);
                    imageView.setId(id);
                    imageView.setImageResource(R.drawable.ic_launcher);
                    RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(
                            RelativeLayout.LayoutParams.WRAP_CONTENT,
                            RelativeLayout.LayoutParams.WRAP_CONTENT);
                    imageView.setPadding(10, 10, 0, 0);
                    imageView.setAdjustViewBounds(true);
                    imageView.setMaxHeight(80);
                    imageView.setMaxWidth(80);
                    if (i == 0) {
                        lp.addRule(RelativeLayout.ALIGN_PARENT_LEFT, RelativeLayout.TRUE);
                    } else {
                        lp.addRule(RelativeLayout.RIGHT_OF, imageView.getId() - 1);
                    }
                    lp.addRule(RelativeLayout.BELOW, belowId);              
                    imageView.setLayoutParams(lp);
                    mainLayout.addView(imageView);
                    id++;
                }           
                belowId = id - 1; 
                rows--; 
            }

また、kcoppock が彼のコメントで既に述べているように、GridView効率のために を検討する価値があるかもしれません。

于 2012-07-20T15:38:56.423 に答える