Мне удалось создать панель управления, похожую на пусковые установки некоторых устройств по умолчанию, реализовав ViewPager и создав собственный PagerAdpter.См. Код ниже:
public class DashboardPagerAdapter extends PagerAdapter {
private static final int ROWS = 4;
private static final int COLS = 4;
private Context mContext;
private List<AppEntry> mData;
public DashboardPagerAdapter(Context context, List<AppEntry> data) {
mContext = context;
mData = data;
}
@Override
public int getCount() {
double ratio = (double) mData.size() / (ROWS * COLS);
return (int) Math.ceil(ratio);
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == ((TableLayout) object);
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
int cols = COLS, rows = ROWS;
switch (mContext.getResources().getConfiguration().orientation) {
case Configuration.ORIENTATION_PORTRAIT:
rows++;
break;
default:
cols++;
}
TableLayout table = new TableLayout(mContext);
table.setStretchAllColumns(true);
table.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,
LayoutParams.MATCH_PARENT));
table.setBackgroundColor(Color.DKGRAY);
int start = position * rows * cols;
int end = Math.min(start + rows * cols, mData.size());
LayoutInflater inflater = LayoutInflater.from(mContext);
for (int i = 0; i < rows; i++) {
TableRow row = new TableRow(mContext);
row.setLayoutParams(new TableLayout.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT, 1f));
row.setGravity(Gravity.CENTER);
for (int j = 0; j < cols; j++) {
int pos = start + i * cols + j;
if (pos < end) {
AppEntry item = mData.get(pos);
View vItem = inflater.inflate(R.layout.grid_item, null,
false);
ImageView image = (ImageView) vItem.findViewById(R.id.icon);
image.setImageDrawable(item.getIcon());
row.addView(vItem);
} else {
TextView vPlaceHolder = new TextView(mContext);
vPlaceHolder.setText(" ");
row.addView(vPlaceHolder);
}
}
table.addView(row);
}
container.addView(table);
return table;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
}
В этом случае метод instantiateItem возвращает TableLayout, который я использую для отображения значков приложения.Я рассчитываю количество страниц (getCount ()) путем деления размера набора данных на количество элементов на странице (строки * столбцы).
Вы можете добавить onClickListener к vItem внутри цикла for на тот случай, если вы хотите обработать это событие.Я бы порекомендовал разделить слушателя между представлениями и запросить тег или идентификатор, прежде чем предпринимать какие-либо действия.
Если ваш контент статический, вы, вероятно, захотите использовать FragmentPagerAdapter и создать один фрагмент для каждой страницы..