티스토리 뷰

반응형

스크롤뷰 안에 RecyclerView를 넣었는데 둘다 스크롤이 되길래 RecyclerView의 길이를 가득 차게 (스크롤이 필요하지 않게) 바꿔줬다.

wrap_content로 한번에 해결이 될것 같았는데 안돼서 알아보느라 정말 고생했다.

 

안드로이드에서는 원래 ScrollView안에 스크롤이 가능한 다른 뷰를 넣지 않아야한다고 강조되어있다. 그래도 원하는 기능을 구현하기 위해서는 어쩔 수 없는 때가 있는데, 그럴때는

 

1. 스크롤이 끊기지 않게 nested scrolling를 막아주고,

2. 내부 뷰의 height를 (가로 스크롤이라면 width) 안의 아이템이 잘리지 않도록 충분히 길게 설정해줘야한다. 

 

nested Scrolling 막기

listview_id.isNestedScrollingEnabled = false

 

 

 

세로 리스트뷰에서 아이템이 잘리지 않게 크기를 설정하려면 가로는 match_parent, 세로는 아이템의 갯수에 따라 가변적이도록 wrap_content로 설정해야한다. 

 

따라서 match_parent를 하기 위해서 화면의 크기를 구했고, wrap_content를 하기 위해 뷰 내부의 아이템 길이에 아이템 갯수를 곱해줬다

 

 

화면 크기 구하기

var size = Point()
windowManager.defaultDisplay.getRealSize(size)

여기서 size.x  size.y 이렇게 접근하면 된다

 

 

뷰의 높이, 넓이 바꾸기

//  아이템 하나의 길이 곱하기 아이템의 갯수 
val len = 298 * editorlist.size

//  px -> dp로 바꿔주는 코드
//  두번째 파라미터는 꼭 float으로 넣어야함 (숫자로 넣을경우 400f 이런식으로)
val height = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, len.toFloat(), resources.displayMetrics).toInt()

//  width는 matchparent : size.x
//  height는 아이템의 길이에 따라 바뀌게 설정
val params = LinearLayout.LayoutParams(size.x, height)

listView_id.layoutParams = params

 

 

반응형