2017-03-24 3 views
0

グリッドビューの最後のアイテムとしてボタンを使用してグリッドビューを作成します。グリッドビューは、追加ボタンとして使用したいものです。例えば追加ボタン付きグリッドビュー

: ボタン(項目1)をクリックしGridViewコントロールに追加して(ボタンを追加)2番目の項目


アイテム1ボタン

アイテム1アイテム2 ITEM3 ITEM4 ボタン

に行きます

トップスタイルのようなもの

+0

チェックこの[チュートリアル](http://chintanrathod.com/recyclerview-android-studio-part-1/) –

答えて

0

1つの可能性は、要件に応じて複数のグリッド・アイテム・レイアウトを設計できます。そして、アダプタクラスの "getView"メソッドでは、どのXMLをビューとして膨張させるかを調べることができます。

希望すると、これを掘るのに役立ちます。

0

ここで私はこれを達成しました。 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()を呼び出します。 それがあなたを助けてくれることを願っています。

enter image description here

関連する問題