gpt4 book ai didi

android - 布局在 Jetpack Compose 中如何工作,它们与 XML 有什么关系?

转载 作者:行者123 更新时间:2023-12-04 07:56:58 26 4
gpt4 key购买 nike

我有一些文字。
我想在屏幕上居中。
我正在使用 Jetpack Compose。
我该怎么做呢?
我知道 Jetpack Compose 中有三种类型的布局。

  • 邮箱
  • 专栏
  • 卧式

  • 我应该使用哪一个?
    我不知道布局是如何工作的。
    它们是否像 XML 一样默认全屏显示?
    如果是这样,我如何定位像 ConstraintLayout 这样的元素?
    如何仅从一侧设置填充和边距以及如何链接元素?

    最佳答案

    如果您关注 Compose Pathway,我想您的所有问题都会得到澄清。 .但我会尽力为你总结......
    您可以使用以下“布局管理器”之一(在 Compose 中称为布局)来组织您的组件:

  • Column (类似于 LinearLayout 垂直方向)
  • Row (类似于 LinearLayout 水平方向)
  • Box (类似于 FrameLayout )
  • ConstraintLayout .
    如果您需要这些不同的东西,您可以使用 Layout 创建自定义布局。可组合的。

  • “我应该使用哪一个?”
    您可以根据具体情况使用其中的任何一种... 要在屏幕中央简单地显示文本,您可以使用所有这些来实现。
    使用 Column :
    Column(
    Modifier.fillMaxSize(), // to fill the whole screen
    verticalArrangement = Arrangement.Center,
    horizontalAlignment = Alignment.CenterHorizontally
    ) {
    Text(text = "Hello")
    }
    使用 Box
    Box(
    Modifier.fillMaxSize()
    ) {
    Text(text = "Hello",
    modifier = Modifier.align(Alignment.Center))
    }
    “它们是否像 XML 一样默认全屏显示?”
    不,默认情况下它们是“wrap_content”。
    “如何定位 ConstraintLayout 之类的元素?如何仅从一侧设置填充和边距以及如何链接元素?”
    您需要声明对组件的引用,然后相应地定位它们。
    这是一个简单的例子......
    ConstraintLayout(modifier = Modifier.fillMaxSize().padding(16.dp)) {
    // Creating refs...
    val (text1Ref, edit1Ref, btn1Ref, btn2Ref) = createRefs()
    Text("Name",
    // Linking the reference to this component
    modifier = Modifier.constrainAs(text1Ref) {
    // linking the top of this component to the parent top
    top.linkTo(parent.top)
    centerHorizontallyTo(parent)
    })
    TextField(
    value = "",
    onValueChange = {},
    label = { Text("Name") },
    modifier = Modifier.padding(top = 8.dp)
    .constrainAs(edit1Ref) {
    start.linkTo(parent.start)
    end.linkTo(parent.end)
    // linking this component with the previous component
    top.linkTo(text1Ref.bottom)
    })
    Button(onClick = {},
    content = { Text("OK") },
    modifier = Modifier.padding(top = 8.dp).constrainAs(btn1Ref) {
    end.linkTo(edit1Ref.end)
    top.linkTo(edit1Ref.bottom)
    }
    )
    TextButton(onClick = {},
    content = { Text("Cancel") },
    modifier = Modifier.padding(end = 8.dp)
    .constrainAs(btn2Ref) {
    end.linkTo(btn1Ref.start)
    baseline.linkTo(btn1Ref.baseline)
    }
    )
    }

    关于android - 布局在 Jetpack Compose 中如何工作,它们与 XML 有什么关系?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66650769/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com