https://ibb.co/p4fJrFf
이러한 이미지의 다이얼로그 창을 구성했습니다.
코틀린으로 변경해서 자바로 작성된 코드를 코틀린 공부할겸 변경중인데
해당 사진은 기존에 리사이클러뷰로 구성했습니다 그런데 아이템 갯수가 적어
재활용될 일이 없기에 리사이클러뷰는 사용하지 않고 단순히
무식하게 LInearLayout에 뷰하나하나 다 넣었습니다.
이제 앱에서 이 뷰들을 선택을 해야하고 값을 가져와야하는데 어떻게 선택해야할지 모르겠습니다.
뷰들을 하나하나 아이디를 가져와서 클릭이벤틀르 설정하면 너무 지저분하고 비효율적인 것같고
리사이클러뷰는 사용안하기로 했으니..
다른 방법이 딱히 떠오르지 않는데, 리니어 레이아웃에서 자식 뷰들을 중복 선택가능하게끔 가져오는
방법이 있을까요?
아 그리고 클릭이벤트에 데이터바인딩도 적용가능해서 한번 해볼생각입니다..
이 데이터 바인딩 방법이면 텍스트뷰 하나하나에 클릭이벤트를 적용해도 findViewByID 하지 않아도 되니
코드도 줄어들고괜찮은 방법일까요
아래는 제가 시도했던 방법인데 이렇게하니 리니어 전체가 클릭되는이벤트가 발생하네요..
class BodyPartDialogFragment : DialogFragment(), View.OnClickListener{
private lateinit var ll: LinearLayout
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
val view: View = inflater.inflate(R.layout.fragment_body_part_dialog, container, false)
ll = view.findViewById(R.id.ll_body_part)
ll.setOnClickListener {
onClick(it)
}
return view
}
override fun onClick(view: View?) {
when (view?.id) {
R.id.back -> Toast.makeText(context, "back", Toast.LENGTH_LONG)
R.id.chest -> Toast.makeText(context, "chest", Toast.LENGTH_SHORT)
R.id.leg -> Toast.makeText(context, "leg", Toast.LENGTH_SHORT)
R.id.shoulder -> Toast.makeText(context, "shoulder", Toast.LENGTH_SHORT)
R.id.bieceps -> Toast.makeText(context, "biceps", Toast.LENGTH_SHORT)
R.id.triceps -> Toast.makeText(context, "triceps", Toast.LENGTH_SHORT)
R.id.abs -> Toast.makeText(context, "abs", Toast.LENGTH_SHORT)
}
}
}
XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:orientation="vertical">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/white">
<TextView
android:id="@+id/back"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text=" 등 "
android:textSize="20dp"
android:background="?attr/selectableItemBackground"
android:gravity="center"
android:padding="15dp" />
<ImageView
android:id="@+id/selection_state1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_dumbbell"
android:backgroundTint="@android:color/transparent"
android:layout_gravity="center_vertical|end"
android:layout_marginRight="20dp"
android:visibility="invisible"/>
</FrameLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/white">
<TextView
android:id="@+id/chest"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text=" 가 슴 "
android:textSize="20dp"
android:background="?attr/selectableItemBackground"
android:gravity="center"
android:padding="15dp" />
<ImageView
android:id="@+id/selection_state2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_dumbbell"
android:backgroundTint="@android:color/transparent"
android:layout_gravity="center_vertical|end"
android:layout_marginRight="20dp"
android:visibility="invisible"/>
</FrameLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/white">
<TextView
android:id="@+id/leg"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text=" 하 체 "
android:textSize="20dp"
android:background="?attr/selectableItemBackground"
android:gravity="center"
android:padding="15dp" />
<ImageView
android:id="@+id/selection_state3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_dumbbell"
android:backgroundTint="@android:color/transparent"
android:layout_gravity="center_vertical|end"
android:layout_marginRight="20dp"
android:visibility="invisible"/>
</FrameLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/white">
<TextView
android:id="@+id/shoulder"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:text=" 어 깨 "
android:textSize="20dp"
android:background="?attr/selectableItemBackground"
android:gravity="center"
android:padding="15dp" />
<ImageView
android:id="@+id/selection_state4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_dumbbell"
android:backgroundTint="@android:color/transparent"
android:layout_gravity="center_vertical|end"
android:layout_marginRight="20dp"
android:visibility="invisible"/>
</FrameLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/white">
<TextView
android:id="@+id/bieceps"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:text=" 이 두 "
android:textSize="20dp"
android:background="?attr/selectableItemBackground"
android:gravity="center"
android:padding="15dp" />
<ImageView
android:id="@+id/selection_state"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_dumbbell"
android:backgroundTint="@android:color/transparent"
android:layout_gravity="center_vertical|end"
android:layout_marginRight="20dp"
android:visibility="invisible"/>
</FrameLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/white">
<TextView
android:id="@+id/triceps"
android:layout_width="300dp"
android:layout_height="wrap_content"
android:text=" 삼 두 "
android:textSize="20dp"
android:background="?attr/selectableItemBackground"
android:gravity="center"
android:padding="15dp" />
<ImageView
android:id="@+id/selection_state6"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_dumbbell"
android:backgroundTint="@android:color/transparent"
android:layout_gravity="center_vertical|end"
android:layout_marginRight="20dp"
android:visibility="invisible"/>
</FrameLayout>
</LinearLayout>