网格布局添加均匀间隔的图像
Grid Layout Add Evenly Spaced Images
我正在尝试以编程方式在网格布局中放置指定数量的图像,我希望它们的大小和分布均匀。每当我尝试添加多张图片时,网格布局只显示一张。我做错了什么?
XML:
<GridLayout
android:id="@+id/gridlayout"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="6"
android:gravity="center"/>
Java:
//reset data and grid
data.clear();
gridLayout.removeAllViews();
Random random = new Random();
for(int i = 0; i < num; i++){
data.add(String.format("%." + 0 + "f", random.nextDouble() * (6 - 1) + 1));
ImageView imageView = new ImageView(getContext());
switch (data.get(i)) {
case "1":
imageView.setImageResource(R.drawable.dice1);
break;
case "2":
imageView.setImageResource(R.drawable.dice2);
break;
case "3":
imageView.setImageResource(R.drawable.dice3);
break;
case "4":
imageView.setImageResource(R.drawable.dice4);
break;
case "5":
imageView.setImageResource(R.drawable.dice5);
break;
default:
imageView.setImageResource(R.drawable.dice6);
break;
}
gridLayout.addView(imageView, i);
}
显示内容:
我想要的:
看看这些属性
android:columnCount="2"
android:rowCount="2"
在将图像添加到 gridview 之前尝试播放上面列出的属性。
如果布局包含 1 张图像,则将两者都设置为 1
如果布局包含 2 个图像,请将行设置为 1,将列设置为 2。
如果布局包含 3 个图像,则将行设置为 1,将列设置为 3
如果布局包含 4,则将两者都设置为 2。
等等...
[![截图][1]][1]
package com.plumtestongo.sample;
import android.os.Build;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.ViewTreeObserver;
import android.widget.GridLayout;
import android.widget.ImageView;
import java.util.ArrayList;
import java.util.Random;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final GridLayout layout = (GridLayout) findViewById(R.id.gridlayout);
ViewTreeObserver vto = layout.getViewTreeObserver();
vto.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.JELLY_BEAN) {
layout.getViewTreeObserver().removeGlobalOnLayoutListener(this);
} else {
layout.getViewTreeObserver().removeOnGlobalLayoutListener(this);
}
int width = layout.getMeasuredWidth();
int height = layout.getMeasuredHeight();
setViews(height, width);
}
});
}
private void setViews(int layoutHeight, int layoutWidth) {
int width = layoutWidth / 3;
int height = layoutHeight / 2;
Log.i(getClass().getName(), "Image height" + height + " Width:" + width);
ArrayList<String> data = new ArrayList<>();
data.clear();
GridLayout gridLayout = (GridLayout) findViewById(R.id.gridlayout);
gridLayout.removeAllViews();
Random random = new Random();
int num = 6;
for (int i = 0; i < num; i++) {
data.add(String.format("%." + 0 + "f", random.nextDouble() * (6 - 1) + 1));
ImageView imageView = new ImageView(this);
GridLayout.LayoutParams layoutParams = new GridLayout.LayoutParams();
layoutParams.width = width;
layoutParams.height = height;
imageView.setLayoutParams(layoutParams);
switch (data.get(i)) {
case "1":
imageView.setImageResource(R.drawable.dice2);
break;
case "2":
imageView.setImageResource(R.drawable.dice2);
break;
case "3":
imageView.setImageResource(R.drawable.dice2);
break;
case "4":
imageView.setImageResource(R.drawable.dice2);
break;
case "5":
imageView.setImageResource(R.drawable.dice2);
break;
default:
imageView.setImageResource(R.drawable.dice2);
break;
}
gridLayout.addView(imageView, i);
}
}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<GridLayout
android:id="@+id/gridlayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:columnCount="3"
android:padding="10dp"
android:gravity="center"/>
</LinearLayout>
- 您需要 xml 布局中的第 3 行。
- 您必须设置 imageview 的宽度和高度。
高宽可以根据屏幕计算size.you不一定
需要高度,但宽度很重要。
另一种选择是为背景创建缩放位图
基于屏幕尺寸的资源。
我正在尝试以编程方式在网格布局中放置指定数量的图像,我希望它们的大小和分布均匀。每当我尝试添加多张图片时,网格布局只显示一张。我做错了什么?
XML:
<GridLayout
android:id="@+id/gridlayout"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="6"
android:gravity="center"/>
Java:
//reset data and grid
data.clear();
gridLayout.removeAllViews();
Random random = new Random();
for(int i = 0; i < num; i++){
data.add(String.format("%." + 0 + "f", random.nextDouble() * (6 - 1) + 1));
ImageView imageView = new ImageView(getContext());
switch (data.get(i)) {
case "1":
imageView.setImageResource(R.drawable.dice1);
break;
case "2":
imageView.setImageResource(R.drawable.dice2);
break;
case "3":
imageView.setImageResource(R.drawable.dice3);
break;
case "4":
imageView.setImageResource(R.drawable.dice4);
break;
case "5":
imageView.setImageResource(R.drawable.dice5);
break;
default:
imageView.setImageResource(R.drawable.dice6);
break;
}
gridLayout.addView(imageView, i);
}
显示内容:
我想要的:
看看这些属性
android:columnCount="2" android:rowCount="2"
在将图像添加到 gridview 之前尝试播放上面列出的属性。
如果布局包含 1 张图像,则将两者都设置为 1 如果布局包含 2 个图像,请将行设置为 1,将列设置为 2。 如果布局包含 3 个图像,则将行设置为 1,将列设置为 3
如果布局包含 4,则将两者都设置为 2。
等等...
[![截图][1]][1]
package com.plumtestongo.sample;
import android.os.Build;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.ViewTreeObserver;
import android.widget.GridLayout;
import android.widget.ImageView;
import java.util.ArrayList;
import java.util.Random;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final GridLayout layout = (GridLayout) findViewById(R.id.gridlayout);
ViewTreeObserver vto = layout.getViewTreeObserver();
vto.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.JELLY_BEAN) {
layout.getViewTreeObserver().removeGlobalOnLayoutListener(this);
} else {
layout.getViewTreeObserver().removeOnGlobalLayoutListener(this);
}
int width = layout.getMeasuredWidth();
int height = layout.getMeasuredHeight();
setViews(height, width);
}
});
}
private void setViews(int layoutHeight, int layoutWidth) {
int width = layoutWidth / 3;
int height = layoutHeight / 2;
Log.i(getClass().getName(), "Image height" + height + " Width:" + width);
ArrayList<String> data = new ArrayList<>();
data.clear();
GridLayout gridLayout = (GridLayout) findViewById(R.id.gridlayout);
gridLayout.removeAllViews();
Random random = new Random();
int num = 6;
for (int i = 0; i < num; i++) {
data.add(String.format("%." + 0 + "f", random.nextDouble() * (6 - 1) + 1));
ImageView imageView = new ImageView(this);
GridLayout.LayoutParams layoutParams = new GridLayout.LayoutParams();
layoutParams.width = width;
layoutParams.height = height;
imageView.setLayoutParams(layoutParams);
switch (data.get(i)) {
case "1":
imageView.setImageResource(R.drawable.dice2);
break;
case "2":
imageView.setImageResource(R.drawable.dice2);
break;
case "3":
imageView.setImageResource(R.drawable.dice2);
break;
case "4":
imageView.setImageResource(R.drawable.dice2);
break;
case "5":
imageView.setImageResource(R.drawable.dice2);
break;
default:
imageView.setImageResource(R.drawable.dice2);
break;
}
gridLayout.addView(imageView, i);
}
}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<GridLayout
android:id="@+id/gridlayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:columnCount="3"
android:padding="10dp"
android:gravity="center"/>
</LinearLayout>
- 您需要 xml 布局中的第 3 行。
- 您必须设置 imageview 的宽度和高度。
高宽可以根据屏幕计算size.you不一定 需要高度,但宽度很重要。
另一种选择是为背景创建缩放位图 基于屏幕尺寸的资源。