Android_app
[JETPACK Compose] Row() 함수
하니_즐거운하루
2022. 11. 22. 12:19
Row() 함수
: 자식 요소를 수평으로 배치시 사용합니다.
modifier
.padding
▶ no padding
▶ all dp 적용하기
.padding(5.dp) // apply 5 dp padding all of each edges (left/top/rigth/bottom)
▶ horizontal && vertical dp 적용하기
.padding(horizontal = 30.dp,vertical =10.dp)
▶ 각각의 edge별로 padding 적용하기
.padding(5.dp,10.dp,15.dp,20.dp) // start / top / end / bottom
.clickable {}
: Rowscope 영역 click 이벤트 발생시 처리기능 추가
.clickable { Toast.makeText(this@MainActivity2,"Clicked Row",Toast.LENGTH_SHORT).show() }
: 여러개의 리스트 중 어는 부분이 클릭 됐는지 확인 하는 방법
@Composable
fun displayBtDevice(btDevice:BluetoothDevice)
{
val addr =btDevice.address
val name =btDevice.name
Row(
modifier = Modifier
.clickable(){
Log.d(MainActivity.TAG,"displayBtDevice = ${btDevice.addr}") <-- 요기
}
~~ 중략 ~~
){
Spacer(modifier = Modifier.size(10.dp))
Text(name)
Spacer(modifier = Modifier.size(50.dp))
Text(addr)
}
Spacer(modifier = Modifier.size(2.dp))
}
>>>>>>> Output <<<<<<<<<<
D/MainActivity: displayBtDevice = C6:E6:20:C1:B4:CD
D/MainActivity: displayBtDevice = C7:61:F0:1D:17:6D
→ 각각이 객체로 생성되므로 파라미터 인자를 읽어서 처리하면 됩니다.
.fillMaxHeight
▶ 미적용 상태
▶ .fillMaxHeight() 적용
▶ .fillMaxHeight(0.5f) 적용
.fillMaxWidth
▶ 미적용 상태
▶ .fillMaxWidth() 적용
▶ .fillMaxWidth(0.7f) 적용
.border
▶ 미적용 상태
.border(BorderStroke(3.dp, Color.Blue), RectangleShape)
.border(BorderStroke(1.dp, Color.White), CircleShape)
.border(BorderStroke(1.dp, Color.White), CutCornerShape(5.dp))
.width() , .height()
: fillMaxSize() 적용안됨
.width(300.dp).height(100.dp)
.width(300.dp).height(100.dp)
.wrapContentSize() // <-- 추가
horizontalArragement
:
Row(
Modifier
.padding(5.dp)
.height(100.dp)
.fillMaxWidth()
.border(BorderStroke(3.dp, Color.Blue), RectangleShape),
) {
Text("1st row", Modifier.background(Color.Red).padding(5.dp))
Text("2nd row",Modifier.background(Color.Yellow).padding(5.dp))
Text("3rd row",Modifier.background(Color.Green).padding(5.dp))
}
horizontalArrangement = Arrangement.Start
==> 초기 상태로 미사용시와 동일합니다.
horizontalArrangement = Arrangement.Center,
horizontalArrangement = Arrangement.End,
<주의사항>
==> 아래처러 행이 가득차 있을경우 horizontalArragement 는 적용이 되지 않습니다.
이 내용은 verticalAlignment 에도 동일합니다.
verticalAlignment
Row(
Modifier
.padding(5.dp)
.height(100.dp)
.fillMaxWidth()
.border(BorderStroke(3.dp, Color.Blue), RectangleShape),
) {
Text("1st row", Modifier.weight(1f).background(Color.Red))
Text("2nd row",Modifier.weight(1f).background(Color.Yellow))
Text("3rd row",Modifier.weight(1f).background(Color.Green))
}
verticalAlignment = Alignment.Top,
verticalAlignment = Alignment.CenterVertically,
verticalAlignment = Alignment.Bottom,
<기타>
A. 3개의 열 각각에 다른 align 적용하기
Column {
Row(modifier= Modifier
.padding(5.dp)
.fillMaxHeight(0.5f)
.border(BorderStroke(3.dp, Color.Blue), RectangleShape),
) {
Text("1st row",modifier= Modifier
.padding(3.dp)
.background(Color.Red,)
.align(Alignment.CenterVertically)
)
Text("2nd row",
modifier= Modifier
.padding(3.dp)
.background(Color.Yellow,)
.align(Alignment.Top)
)
Text("3rd row",modifier= Modifier
.padding(3.dp)
.background(Color.Green,)
.align(Alignment.Bottom)
)
}
}
B> alignment , arrangement 사전적 의미
C> Column 안에 2개의 Row 추가 및 각 Row 에 Text() 3개 넣기
Surface (color = Color.LightGray){
Column {
Row(
Modifier
.padding(5.dp)
.width(300.dp).height(100.dp)
.border(BorderStroke(3.dp, Color.Blue), RectangleShape)
.background(Color.Cyan),
horizontalArrangement = Arrangement.Center,
verticalAlignment = Alignment.CenterVertically,
) {
Text("1-1 row", Modifier.background(Color.Red).padding(5.dp))
Text("1-2 row",Modifier.background(Color.Yellow).padding(5.dp))
Text("1-3 row",Modifier.background(Color.Green).padding(5.dp))
}
Row(
Modifier
.padding(5.dp)
.width(300.dp).height(100.dp)
.border(BorderStroke(3.dp, Color.Green), RectangleShape)
.background(Color.Gray),
horizontalArrangement = Arrangement.Center,
verticalAlignment = Alignment.CenterVertically,
) {
Text("2-1 row", Modifier.background(Color.Red).padding(5.dp))
Text("2-2 row",Modifier.background(Color.Yellow).padding(5.dp))
Text("2-3 row",Modifier.background(Color.Green).padding(5.dp))
}
}
}
D> 버튼사이 간격 추가하기
Row(modifier = Modifier.fillMaxWidth().padding(bottom = 10.dp),
horizontalArrangement = Arrangement.SpaceEvenly,){
Button(
onClick={},
){
Text("PING")
}
Button(
onClick={},
){
Text("SET NAME")
}
}
Button(
onClick={},
){
Text("EN NOTI")
}
}
반응형