컴퓨터/이론: 안드로이드
clipChildren 개념 및 실습
heepie
2019. 8. 13. 00:01
도입
이번 포스팅에서는 clipChildren 속성에 대해 알아볼 예정이다.
개념
clipChildren는 자식 View가 그려지는 것에 대한 제한을 설정할지 말지에 대한 속성이다.
기본으로 true(자식 View가 그려지는 것에 대한 제한 O)으로 설정되어 있다.
https://developer.android.com/reference/android/view/ViewGroup#attr_android:clipChildren
공식 문서에서 처럼 스케일이 커지는 애니메이션처럼 View가 ViewGroup을 넘어가는 경우 유용하다.
실습
Step1. 스케일이 커지는 애니메이션 설정
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
private val scaleAnimation: Animation = ScaleAnimation(
1f,
ANI_SCALE,
1f,
ANI_SCALE,
ScaleAnimation.RELATIVE_TO_SELF,
0.5f,
ScaleAnimation.RELATIVE_TO_SELF,
0.5f
).apply {
duration = ANI_DURATION
}
fun onClickImage(v: View) {
targetIv.run {
clearAnimation()
isSelected = !isSelected
startAnimation(scaleAnimation)
}
}
|
cs |
Step2. clipChildren 설정
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:clipChildren="false"
android:background="@color/colorPrimary"
tools:context=".MainActivity">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorAccent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent">
<ImageView
android:id="@+id/target_iv"
android:layout_width="100dp"
android:layout_height="100dp"
android:onClick="onClickImage"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/selector_image" />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
|
cs |
1
2
3
4
|
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@android:drawable/btn_star_big_on" android:state_selected="true" />
<item android:drawable="@android:drawable/btn_star_big_off" android:state_selected="false" />
</selector>
|
cs |
여기서 주의해야할 점은 설정을 ViewGroup02이 아닌 ViewGroup01에 해야한다.
ViewGroup01의 children인 View01가 그려지는 것에 대한 제한을 풀어주기 위함이기 때문이다.
스크린 샷
AS-IS | TO-BE |
#clipChildren #android:clipChildren #앱개발 #모바일앱개발 #어플개발