グリッドビューの最後のアイテムとしてボタンを使用してグリッドビューを作成します。グリッドビューは、追加ボタンとして使用したいものです。例えば追加ボタン付きグリッドビュー
: ボタン(項目1)をクリックしGridViewコントロールに追加して(ボタンを追加)2番目の項目
アイテム1ボタン
アイテム1アイテム2 ITEM3 ITEM4 ボタン
に行きますトップスタイルのようなもの
グリッドビューの最後のアイテムとしてボタンを使用してグリッドビューを作成します。グリッドビューは、追加ボタンとして使用したいものです。例えば追加ボタン付きグリッドビュー
: ボタン(項目1)をクリックしGridViewコントロールに追加して(ボタンを追加)2番目の項目
アイテム1ボタン
アイテム1アイテム2 ITEM3 ITEM4 ボタン
に行きますトップスタイルのようなもの
1つの可能性は、要件に応じて複数のグリッド・アイテム・レイアウトを設計できます。そして、アダプタクラスの "getView"メソッドでは、どのXMLをビューとして膨張させるかを調べることができます。
希望すると、これを掘るのに役立ちます。
ここで私はこれを達成しました。 MainActivityクラス:
public class MainActivity extends AppCompatActivity {
GridView gridView;
GridAdapter adapter;
List<String> list;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
list = new ArrayList<>();
for (int i = 0; i < 5; i++) {
list.add("Test " + i);
}
gridView = (GridView) findViewById(R.id.gridView);
adapter = new GridAdapter(this, list);
gridView.setAdapter(adapter);
}
}
Main.xmlは
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.stackoverflow.MainActivity">
<GridView
android:id="@+id/gridView"
android:layout_width="match_parent"
android:layout_height="match_parent">
</GridView>
</RelativeLayout>
今のGridView
public class GridAdapter extends BaseAdapter {
List<String> list;
Context context;
public GridAdapter(Context context, List<String> list) {
this.list = list;
this.context = context;
}
@Override
public int getCount() {
return list.size();
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = inflater.inflate(R.layout.griditem, parent, false);
}
TextView textView = (TextView) view.findViewById(R.id.textView);
LinearLayout linearLayout = (LinearLayout) view.findViewById(R.id.linearLayout);
textView.setText(list.get(position));
if (list.size() - 1 == position) {
linearLayout.addView(addButton());
}
return view;
}
private Button addButton() {
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT);
Button button = new Button(context);
button.setLayoutParams(params);
button.setText("Testing");
return button;
}
}
用のアダプタを作成し、gridItem.xmlは
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/linearLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="Testing"
android:textAppearance="@style/TextAppearance.AppCompat.Headline"
android:textStyle="bold" />
</LinearLayout>
それがメインですアイデアtあなたは最後のアイテムを取得し、最後にボタンを追加します。あなたはこのコードを改良することができ、またrecyclerViewを使うこともできます。次に、リストに項目を追加した後、notifyDataSetChanged()を呼び出します。 それがあなたを助けてくれることを願っています。
チェックこの[チュートリアル](http://chintanrathod.com/recyclerview-android-studio-part-1/) –