일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- HashMap
- android progressbar setIndeterminateDrawable not working
- java hashmap sorting
- android google account add call
- android border custom
- nougat
- bindservice
- Messenger
- progressbar custom marshmallow
- android layout border
- progressbar rounding
- app to app transaction
- android device add account
- Today
- Total
기타치는 개발자
[Android]VIew 에 원하는 곳에만 border 주기 본문
위와 같은 표 형식의 UI의 개발이 필요할때가 있습니다.
물론 GrideView나 RecylerView 쓰고 제공되는 API 쓰거나 각 셀에 패딩을 줘서 처리를 할 수도 있습니다.
하지만 가끔 저 두가지를 쓰지 못하고 직접 ViewGroup에 넣어야될 경우가 있다.
이 경우에 각 셀에 라인을 위,아래,좌측,우측 을 다 줄경우
겹치는 라인이 두줄로 표시되기때문에 우측,아래 border값만 지정하여 해결할수 있습니다.
여기서 또 요청사항이 각 셀에 대한 Press 상태도 표시를 해야될경우가 있습니다.
이와같은 경우는 아래와같이 해결하게됩니다.
우선 VIew에 들어갈 Pressed 상태로 Selector에 들어갈 파일을 작성한다.
layout_border.xml(state_pressed="false" 상태 레이아웃)
<?xml version="1.0" encoding="utf-8"?>
<inset xmlns:android="http://schemas.android.com/apk/res/android"
android:insetTop="-1dp"
android:insetLeft="-1dp">
<shape android:shape="rectangle">
<stroke android:width="1dp" android:color="#dfdfdf" />
<solid android:color="#ffffff" />
</shape>
</inset>
layout_border_press.xml(state_pressed="true" 상태 레이아웃)
<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#ffffff" />
<stroke
android:width="3px"
android:color="#86E57F" />
<padding
android:bottom="3px"
android:left="3px"
android:right="3px"
android:top="3px" />
</shape>
layout_pressed_selector.xml(셀에 들어갈 셀렉터)
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- pressed -->
<item android:state_pressed="true" android:drawable="@drawable/layout_border_press" />
<item android:state_pressed="false" android:drawable="@drawable/layout_border"/>
</selector>
이제 적용할 뷰에
<View
android:layout_width="114px"
android:layout_height="56px"
android:layout_centerInParent="true"
android:background="@drawable/layout_pressed_selector" />
'안드로이드 > Android' 카테고리의 다른 글
[Android]Messenger를 사용하여 앱 간 통신하기 (0) | 2016.10.17 |
---|---|
[Android]Nougat 버전 대응하기 (0) | 2016.09.13 |
[Android]미디어 파일 새로고침 관련(MediaScannerConnection) (0) | 2016.09.08 |