2017-03-24 5 views
0

gridview의 마지막 항목으로 버튼을 사용하여 gridview를 만들겠습니다. 추가 버튼으로 사용하고 싶습니다. 예를 들어추가 버튼이있는 Gridview

: 버튼 (항목 1)을 클릭있는 gridview에 추가 (버튼을 추가) 두 번째 항목


항목 1 버튼

항목 1 항목 2 항목 3 Item4 버튼

로 이동

톱 스타일과 같은 것

+0

확인이 [튜토리얼 (http://chintanrathod.com/recyclerview-android-studio-part-1/) –

답변

0

하나의 가능성은 요구 사항에 따라 여러 그리드 항목 레이아웃을 설계 할 수 있다는 것입니다. 그런 다음 Adapter 클래스의 "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> 

이 메인입니다 아이디어 모자 당신은 마지막 항목을 얻고 마침내 버튼을 추가합니다. 이 코드를 수정하고 recyclerView를 사용할 수도 있습니다. 이제 목록에 항목을 추가 한 다음 notifyDataSetChanged();를 호출하십시오. 희망이 있으면 도움이 될 것입니다.

enter image description here