LinearLayout 내부의 모든 자식 뷰를 한 번에 가져옵니다.


140

나는 LinearLayout여러 자녀를 포함하고 있습니다 TextViews. 루프를 사용하여 해당 LineLayout의 자식 뷰를 얻으려면 어떻게해야합니까?

답변:


282

getChildCount()및을 사용하십시오 getChildAt(int index).

예:

LinearLayout ll = 
final int childCount = ll.getChildCount();
for (int i = 0; i < childCount; i++) {
      View v = ll.getChildAt(i);
      // Do something with v.
      // …
}

Yashwanth Kumar 안녕하세요, 해당 Linearlayout의 모든 TextView를 얻을 수 있습니까?
Hai nguyen

15
@ hai-nguyen : if (v instanceof TextView) {...}를 사용할 수 있습니다.
Anoop

3
자식 중 하나가 ViewGroup이고 모든 자식도 가져 오려면 어떻게해야합니까?
Hendra Anggrian

buttons선형 레이아웃 에 추가 된 것을 전혀 얻지 않고 2 만큼 나눌 수 있습니까? 내 목적은 선형 레이아웃을 사용하여 2 행의 단추를 표시하는 것입니다 .
Jay Rathod RJ

39
((ViewGroup) findViewById(android.R.id.content));// you can use this in an Activity to get your layout root view, then pass it to findAllEdittexts() method below.

여기서는 EdiText 만 반복하고 있습니다. 모든보기를 원하면 EditText를 View로 바꿀 수 있습니다.

SparseArray<EditText> array = new SparseArray<EditText>();

private void findAllEdittexts(ViewGroup viewGroup) {

    int count = viewGroup.getChildCount();
    for (int i = 0; i < count; i++) {
        View view = viewGroup.getChildAt(i);
        if (view instanceof ViewGroup)
            findAllEdittexts((ViewGroup) view);
        else if (view instanceof EditText) {
            EditText edittext = (EditText) view;
            array.put(editText.getId(), editText);
        }
    }
}

명확하게 getChildAt
말하면

4

이것을 사용하십시오

    final int childCount = mainL.getChildCount();
    for (int i = 0; i < childCount; i++) {
          View element = mainL.getChildAt(i);

        // EditText
        if (element instanceof EditText) {
            EditText editText = (EditText)element;
            System.out.println("ELEMENTS EditText getId=>"+editText.getId()+ " getTag=>"+element.getTag()+
            " getText=>"+editText.getText());
        }

        // CheckBox
        if (element instanceof CheckBox) {
            CheckBox checkBox = (CheckBox)element;
            System.out.println("ELEMENTS CheckBox getId=>"+checkBox.getId()+ " getTag=>"+checkBox.getTag()+
            " getText=>"+checkBox.getText()+" isChecked=>"+checkBox.isChecked());
        }

        // DatePicker
        if (element instanceof DatePicker) {
            DatePicker datePicker = (DatePicker)element;
            System.out.println("ELEMENTS DatePicker getId=>"+datePicker.getId()+ " getTag=>"+datePicker.getTag()+
            " getDayOfMonth=>"+datePicker.getDayOfMonth());
        }

        // Spinner
        if (element instanceof Spinner) {
            Spinner spinner = (Spinner)element;
            System.out.println("ELEMENTS Spinner getId=>"+spinner.getId()+ " getTag=>"+spinner.getTag()+
            " getSelectedItemId=>"+spinner.getSelectedItemId()+
            " getSelectedItemPosition=>"+spinner.getSelectedItemPosition()+
            " getTag(key)=>"+spinner.getTag(spinner.getSelectedItemPosition()));
        }

    }

3

for-in 루프를 사용하여 Kotlin을 사용하는 것이 더 쉽습니다.

for (childView in ll.children) {
     //childView is a child of ll         
}

다음 ll은 레이아웃 XML idLinearLayout정의되어 있습니다.


1

모든 유형의 레이아웃에서 모든 뷰 가져 오기

public List<View> getAllViews(ViewGroup layout){
        List<View> views = new ArrayList<>();
        for(int i =0; i< layout.getChildCount(); i++){
            views.add(layout.getChildAt(i));
        }
        return views;
}

모든 유형의 레이아웃에서 모든 TextView 가져 오기

public List<TextView> getAllTextViews(ViewGroup layout){
        List<TextView> views = new ArrayList<>();
        for(int i =0; i< layout.getChildCount(); i++){
            View v =layout.getChildAt(i);
            if(v instanceof TextView){
                views.add((TextView)v);
            }
        }
        return views;
}

-1

Kotlin에서 뷰와 해당 뷰의 모든 뷰를 재귀 적으로 가져옵니다.

private fun View.getAllViews(): List<View> {
    if (this !is ViewGroup || childCount == 0) return listOf(this)

    return children
            .toList()
            .flatMap { it.getAllViews() }
            .plus(this as View)
}
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.