gridview의 마지막 항목으로 버튼을 사용하여 gridview를 만들겠습니다. 추가 버튼으로 사용하고 싶습니다. 예를 들어추가 버튼이있는 Gridview
: 버튼 (항목 1)을 클릭있는 gridview에 추가 (버튼을 추가) 두 번째 항목
항목 1 버튼
항목 1 항목 2 항목 3 Item4 버튼
로 이동톱 스타일과 같은 것
gridview의 마지막 항목으로 버튼을 사용하여 gridview를 만들겠습니다. 추가 버튼으로 사용하고 싶습니다. 예를 들어추가 버튼이있는 Gridview
: 버튼 (항목 1)을 클릭있는 gridview에 추가 (버튼을 추가) 두 번째 항목
항목 1 버튼
항목 1 항목 2 항목 3 Item4 버튼
로 이동톱 스타일과 같은 것
하나의 가능성은 요구 사항에 따라 여러 그리드 항목 레이아웃을 설계 할 수 있다는 것입니다. 그런 다음 Adapter 클래스의 "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>
이 메인입니다 아이디어 모자 당신은 마지막 항목을 얻고 마침내 버튼을 추가합니다. 이 코드를 수정하고 recyclerView를 사용할 수도 있습니다. 이제 목록에 항목을 추가 한 다음 notifyDataSetChanged();를 호출하십시오. 희망이 있으면 도움이 될 것입니다.
확인이 [튜토리얼 (http://chintanrathod.com/recyclerview-android-studio-part-1/) –