Android XML 约束布局 参考
TextView居中
data:image/s3,"s3://crabby-images/81714/81714983e6956726619d6feaa65d87bd1d03f69c" alt=""
TextView 垂直居中并且靠右
data:image/s3,"s3://crabby-images/873fa/873fa0329bddc97f709da25ace25f1694bab7f43" alt=""
TextView 宽高设置百分比
宽和高的比例
app:layout_constraintDimensionRatio="h,2:1"
表示子视图的宽高比为2:1,其中 h
表示保持宽度不变,高度自动调整。
data:image/s3,"s3://crabby-images/3f879/3f879914bd27f62867e8080e17776eafd1316e78" alt=""
最大宽度
设置最大宽度,超过这个宽度就会发生换行。
data:image/s3,"s3://crabby-images/fe9cb/fe9cb88ba8c5a274853b33f6677dd161183c69bc" alt=""
Android Compose 约束布局
导入依赖包
data:image/s3,"s3://crabby-images/1167c/1167cd464677649a47f4ffea417674ecaaa30069" alt=""
启用Compose
data:image/s3,"s3://crabby-images/f82da/f82da9d6dd254eb1af4577bf28c0520e419421c2" alt=""
Compose Text居中
Dart
//Compose Text居中
@Preview
@Composable
fun ConstraintLayoutCompose() {
ConstraintLayout(modifier = Modifier.fillMaxSize()) {
val (text) = createRefs()
Text(
text = "Text 居中",
modifier = Modifier
.width(180.dp)// 宽度
.height(200.dp)// 高度
.background(color = Color.Cyan)
.constrainAs(text) {
start.linkTo(parent.start)//位于父视图开始
end.linkTo(parent.end)//位于父视图结束
top.linkTo(parent.top)//位于父视图顶部
bottom.linkTo(parent.bottom)//位于父视图底部
},
textAlign = TextAlign.Center,
)
}
}
data:image/s3,"s3://crabby-images/affd3/affd32712e90d3087a09e709a9a938cb97b80a21" alt=""
Compose Text 垂直居中并且靠右
Dart
// Compose Text 垂直居中并且靠右
@Preview
@Composable
fun ConstraintLayoutCompose() {
ConstraintLayout(modifier = Modifier.fillMaxSize()) {
val (text) = createRefs()
Text(
text = "Text 居中",
modifier = Modifier
.width(180.dp)// 宽度
.height(200.dp)// 高度
.background(color = Color.Cyan)
.constrainAs(text) {
end.linkTo(parent.end)//位于父视图结束
top.linkTo(parent.top)//位于父视图顶部
bottom.linkTo(parent.bottom)//位于父视图底部
},
textAlign = TextAlign.Center,
)
}
}
data:image/s3,"s3://crabby-images/3cddb/3cddbab3bb2647eab472c01186d7979f0d7288d7" alt=""
Compose Text 宽高设置百分比
Dart
// Compose Text 宽高设置百分比
@Preview
@Composable
fun ConstraintLayoutCompose() {
ConstraintLayout(modifier = Modifier.fillMaxSize()) {
val (text) = createRefs()
Text(
text = "Text 居中",
modifier = Modifier
.background(color = Color.Cyan)
.constrainAs(text) {
start.linkTo(parent.start) // 位于父视图开始
end.linkTo(parent.end)//位于父视图结束
top.linkTo(parent.top)//位于父视图顶部
bottom.linkTo(parent.bottom)//位于父视图底部
// 设置宽度为父视图宽度的50%
width = Dimension.percent(0.5F)
// 设置高度为父视图宽度的50%
height = Dimension.percent(0.5F)
},
textAlign = TextAlign.Center,
)
}
}
data:image/s3,"s3://crabby-images/434b0/434b078cf42f929575447fb1a9e0e26d490be2a3" alt=""
Compose Text 宽和高的比例 2:1
Dart
// Compose Text 宽和高的比例 2:1
@Preview
@Composable
fun ConstraintLayoutCompose() {
ConstraintLayout(modifier = Modifier.fillMaxSize()) {
val (text) = createRefs()
Text(
text = "Text 居中",
textAlign = TextAlign.Center,
modifier = Modifier
.background(color = Color.Cyan)
.constrainAs(text) {
start.linkTo(parent.start) // 位于父视图开始
end.linkTo(parent.end)//位于父视图结束
top.linkTo(parent.top)//位于父视图顶部
bottom.linkTo(parent.bottom)//位于父视图底部
// 设置宽度为父视图宽度的100%
width = Dimension.percent(1.0f)
}
.aspectRatio(2.0f)// 宽高比例 2:1
)
}
}
data:image/s3,"s3://crabby-images/0dc28/0dc289514d2cfac267e702c012a98a1d5268a1a9" alt=""
Compose Text 设置最大宽度
Dart
//Compose Text 设置最大宽度
@Preview
@Composable
fun ConstraintLayoutCompose() {
ConstraintLayout(modifier = Modifier.fillMaxSize()) {
val (text) = createRefs()
Text(
text = "Compose Text 设置最大宽度 Compose Text 设置最大宽度 Compose Text 设置最大宽度 ",
textAlign = TextAlign.Start,
modifier = Modifier
.background(color = Color.Cyan)
.widthIn(max = 160.dp) // 设置最大宽度
.constrainAs(text) {
start.linkTo(parent.start) // 位于父视图开始
end.linkTo(parent.end)//位于父视图结束
top.linkTo(parent.top)//位于父视图顶部
bottom.linkTo(parent.bottom)//位于父视图底部
}
)
}
}
data:image/s3,"s3://crabby-images/5cbf7/5cbf7d4447aeb0cd3d00f7f60baa8f55f30c21b4" alt=""
IOS Object-c 约束布局
pod init
如果不存在 Podfile 文件,切换到工程目录,就执行**pod init
**命令
pod install
配置 Masonry
依赖 ,然后执行 pod install
命令
data:image/s3,"s3://crabby-images/ed851/ed85161e3012002aa8d4de61a2ee2d65318ad5b0" alt=""
data:image/s3,"s3://crabby-images/9ab92/9ab9211485dde60c8909aec957cd47a87de06d39" alt=""
编译是遇到的问题 参考
file not found libarclite_iphonesimulator.a
data:image/s3,"s3://crabby-images/9684c/9684cb8d264a278a28b27f52f8f9025d88c08bc6" alt=""
data:image/s3,"s3://crabby-images/fcae9/fcae922da2b070bc834c3485762055ecb5e38280" alt=""
Podfile 中添加脚本 将Cocopods 引入的库的最低版本改为 iOS 11.0,再次执行 pod install 命令
data:image/s3,"s3://crabby-images/9be5e/9be5edbea60aad6110ed66630f63ce76b549c626" alt=""
UITextView 居中
data:image/s3,"s3://crabby-images/92b0c/92b0c7c2151a419f91d15d60fc612ddfa4125ad6" alt=""
data:image/s3,"s3://crabby-images/cc736/cc736eed31c348f2cee40b8d82779fbec3c9c400" alt=""
UITextView 垂直居中并且靠右
data:image/s3,"s3://crabby-images/5150d/5150dacf744eccae8438e14c00f658d6a3b2736b" alt=""
data:image/s3,"s3://crabby-images/90dd2/90dd2c1a61c0a0d16587b257e1f427acad9d6325" alt=""
UITextView 宽和高的比例 2:1
data:image/s3,"s3://crabby-images/49298/4929860eb79ea60c6846397fc362a3b98e5f4a99" alt=""
data:image/s3,"s3://crabby-images/56634/566344a8b38e77ee3cd7c0c22cc31753c53807d4" alt=""
UITextView 最大宽度
data:image/s3,"s3://crabby-images/a195f/a195fe93c23ae1d26294d9dfd240488890852631" alt=""
data:image/s3,"s3://crabby-images/485d1/485d19a00f9f976115786dc247c5409ec98341bb" alt=""
IOS Swifit 约束布局
pod init
如果不存在 Podfile 文件,切换到工程目录,就执行 pod init
命令
pod install
配置 Masonry
依赖 ,然后执行 pod install
命令
data:image/s3,"s3://crabby-images/c06b0/c06b029e3777c625dfaf290e45aba5dca1f1da57" alt=""
UITextView 居中
data:image/s3,"s3://crabby-images/5d92c/5d92ca8d9f1da70712798ef888d4f790575092f6" alt=""
UITextView 垂直居中并且靠右
data:image/s3,"s3://crabby-images/d560b/d560bd6ef787ada3838742fe861e2a70bb43a59e" alt=""
UITextView 宽和高的比例 2:1
UITextView 最大宽度
data:image/s3,"s3://crabby-images/5a30e/5a30eee1d90e6be3fa7c8353b5605c3993598cf1" alt=""
Flutter 约束布局
配置依赖
pubspec.yaml 里面配置 flutter_constraintlayout
依赖
data:image/s3,"s3://crabby-images/f3894/f3894cb76e15b3e05022530907e299efc2fe7a83" alt=""
Flutter Text居中
Dart
// flutter text 居中显示
Widget textCenter() {
return ConstraintLayout(
children: [
Container(
color: Colors.orange,
alignment: Alignment.center,
child: const Text('flutter text 居中'),
).applyConstraint(
width: 200.0,
height: 100.0,
centerTo: parent, // Text 居中
)
],
);
}
data:image/s3,"s3://crabby-images/6cf58/6cf585143620d0d8f2034c5ff2d30caa490c824f" alt=""
Flutter Text 垂直居中靠右显示
Dart
// flutter text 垂直居中靠右显示
Widget textVerticalCenterToRight() {
return ConstraintLayout(
children: [
Container(
color: Colors.orange,
alignment: Alignment.center,
child: const Text('flutter text 居中'),
).applyConstraint(
width: 200.0, height: 100.0, centerRightTo: parent // 垂直居中 靠右显示
)
],
);
}
data:image/s3,"s3://crabby-images/685b9/685b9e84a9b8b12724a5a44f6a3ab578ebe4a869" alt=""
Flutter Text 宽高设置百分比
Dart
// flutter text 宽高设置百分比
Widget textWidthHeightPercent() {
return ConstraintLayout(
children: [
Container(
color: Colors.orange,
alignment: Alignment.center,
child: const Text('flutter text 宽高设置百分比'),
).applyConstraint(
width: matchConstraint,
height: matchConstraint,
heightPercent: 0.5,
widthPercent: 0.5,
centerTo: parent
)
],
);
}
data:image/s3,"s3://crabby-images/d098b/d098b709b2b7976046b824ee9c3404cc8ae1e1e2" alt=""
Flutter Text 宽和高的比例 2:1
Dart
// flutter 宽高比例 2:1
Widget textWidthHeightRatio() {
return ConstraintLayout(
children: [
Container(
color: Colors.orange,
alignment: Alignment.center,
child: const Text('flutter 宽高比例 2:1'),
).applyConstraint(
width: 300,
height: matchConstraint,
widthHeightRatio: 2 / 1,
centerTo: parent)
],
);
}
data:image/s3,"s3://crabby-images/60d6a/60d6a1534d5057d7a7efc4aa8ddaddb87fcc7db3" alt=""
Flutter 设置最大宽度
Dart
// flutter 设置最大宽度
Widget textMaxWidth() {
return ConstraintLayout(
children: [
Container(
color: Colors.orange,
alignment: Alignment.center,
child:
const Text('flutter 最大宽度 flutter 最大宽度 flutter 最大宽度 flutter 最大宽度'),
).applyConstraint(maxWidth: 200, height: 400, centerTo: parent)
],
);
}
data:image/s3,"s3://crabby-images/d0d02/d0d0271261cd827a540619eb3c9516f0c701a574" alt=""
鸿蒙 布局 Flexbox
鸿蒙 Text 居中
Dart
@Entry
@Component
struct Index {
build() {
// 鸿蒙 Text 居中
Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
Text('鸿蒙 Text 居中').width('50%').height(80)
.textAlign(TextAlign.Center)
.backgroundColor(0xF5DEB3)
}.width('100%').height('100%').backgroundColor(0xFFFFFFFF)
}
}
data:image/s3,"s3://crabby-images/1709d/1709d388a5c60242516b101fc29b65885eaebaca" alt=""
鸿蒙 Text 垂直居中靠右
Dart
@Entry
@Component
struct Index {
build() {
// 鸿蒙 Text 垂直居中靠右
Flex({
alignItems: ItemAlign.Center, //垂直居中
justifyContent: FlexAlign.End //水平靠右
}) {
Text('鸿蒙 Text 居中').width('50%').height(80)
.textAlign(TextAlign.Center)
.backgroundColor(0xF5DEB3)
}.width('100%').height('100%').backgroundColor(0xFFFFFFFF)
}
}
data:image/s3,"s3://crabby-images/5a07d/5a07d99a68179ac5c764c94daa63edfc95f3aec3" alt=""
鸿蒙 宽和高的比例 2:1
Dart
@Entry
@Component
struct Index {
build() {
// 鸿蒙 宽和高的比例 2:1
Flex({
alignItems: ItemAlign.Center, //垂直居中
justifyContent: FlexAlign.End //水平靠右
}) {
Text('鸿蒙 宽和高的比例 2:1').width('100%')
.aspectRatio(2) //宽高比例 2:1
.textAlign(TextAlign.Center)
.backgroundColor(0xF5DEB3)
}.width('100%').height('100%').backgroundColor(0xFFFFFFFF)
}
}
data:image/s3,"s3://crabby-images/4ace1/4ace117adfddbc59ae9334c950f7523183264dea" alt=""
鸿蒙 Text 设置最大宽度
Dart
@Entry
@Component
struct Index {
build() {
// 鸿蒙 最大宽度
Flex({
alignItems: ItemAlign.Center, //垂直居中
justifyContent: FlexAlign.Center //水平居中
}) {
Text('鸿蒙 最大宽度 鸿蒙 最大宽度 鸿蒙 最大宽度 鸿蒙 最大宽度')
.constraintSize({
maxWidth: 160 //最大宽度
})
.textAlign(TextAlign.Center)
.backgroundColor(0xF5DEB3)
}.width('100%').height('100%').backgroundColor(0xFFFFFFFF)
}
}
data:image/s3,"s3://crabby-images/f39b2/f39b2cf9c817ed3b5e24745218afeef9c456b7e7" alt=""
ReactNative Flexbox
ReactNative Text 居中
Dart
import React from 'react';
import {AppRegistry,View,Text } from 'react-native';
import App from './App';
import {name as appName} from './app.json';
const CenteredText = () => (
<View style={{
flex: 1,
justifyContent: 'center',//内容垂直居中
alignItems: 'center' // 内容水平居中
}}>
<Text style={{
backgroundColor: '#6200EE', // 背景颜色
height:60.0, //高度
width: '80%', // 宽度
textAlign: 'center', // 文本水平居中
color: '#ffffff', // 文本颜色
textAlignVertical: 'center',//文本垂直居中
}}>
React Native 居中文本
</Text>
</View>
);
AppRegistry.registerComponent(appName, () => CenteredText);
data:image/s3,"s3://crabby-images/b953e/b953ea5f4d3c0ae336e6dc8c8bf6e03faa58bbd2" alt=""
执行 npm install 安装项目所需要的依赖
data:image/s3,"s3://crabby-images/edeb8/edeb88d67d90b4586b2074f666b8e99c97e2b4b2" alt=""
运行到安卓
采用 npx react-native run-android 或npm start 运行
data:image/s3,"s3://crabby-images/4ffbc/4ffbc97a709365734ff3ca1cd29b150bf9aa6b77" alt=""
运行到IOS平台
采用 npx react-native run-ios 或npm start 运行
切换到iOS目录从新安装依赖
Dart
// 清除缓存
pod cache clean --all
//移出本地 pod文件依赖
pod deintegrate
//执行安装显示下载信息
pod install --verbose --no-repo-update
data:image/s3,"s3://crabby-images/8a420/8a4205466f266f4b93e7f6dfb9c7eb2a4fad0bf4" alt=""
ReactNative Text 垂直居中并且靠右
Dart
import React from 'react';
import {AppRegistry,View,Text } from 'react-native';
import App from './App';
import {name as appName} from './app.json';
const CenteredText = () => (
<View style={{
flex: 1,
justifyContent: 'center',//内容垂直居中
alignItems: 'flex-end' // 内容居右
}}>
<Text style={{
backgroundColor: '#6200EE', // 背景颜色
height:60.0, //高度
width: '80%', // 宽度
textAlign: 'center', // 文本水平居中
color: '#ffffff', // 文本颜色
textAlignVertical: 'center',//文本垂直居中
}}>
React Native 居中文本
</Text>
</View>
);
AppRegistry.registerComponent(appName, () => CenteredText);
data:image/s3,"s3://crabby-images/7f50d/7f50d5c7d9da3e46e9eada6a6ea3a0c6df6526ac" alt=""
ReactNative Text 宽和高的比例 2:1
Dart
import React from 'react';
import {AppRegistry,View,Text } from 'react-native';
import App from './App';
import {name as appName} from './app.json';
const CenteredText = () => (
<View style={{
flex: 1,
justifyContent: 'center',//内容垂直居中
alignItems: 'center' // 内容水平居中
}}>
<Text style={{
backgroundColor: '#6200EE', // 背景颜色
width: '80%', // 宽度
textAlign: 'center', // 文本水平居中
color: '#ffffff', // 文本颜色
textAlignVertical: 'center',//文本垂直居中
aspectRatio: 2, // 宽高比为2:1
}}>
ReactNative Text 宽和高的比例 2:1
</Text>
</View>
);
AppRegistry.registerComponent(appName, () => CenteredText);
data:image/s3,"s3://crabby-images/3a203/3a203231468ff5d55cb9e31fc065db29baf79958" alt=""
ReactNative Text 最大宽度
Dart
import React from 'react';
import {AppRegistry,View,Text } from 'react-native';
import App from './App';
import {name as appName} from './app.json';
const CenteredText = () => (
<View style={{
flex: 1,
justifyContent: 'center',//内容垂直居中
alignItems: 'center' // 内容水平居中
}}>
<Text style={{
backgroundColor: '#6200EE', // 背景颜色
maxWidth: '50%', // 最大宽度
textAlign: 'center', // 文本水平居中
color: '#ffffff', // 文本颜色
textAlignVertical: 'center',//文本垂直居中
}}>
ReactNative Text 最大宽度 ReactNative Text 最大宽度 ReactNative Text 最大宽度
</Text>
</View>
);
AppRegistry.registerComponent(appName, () => CenteredText);
data:image/s3,"s3://crabby-images/2ada7/2ada7ea213ef4ef0a0698c4effb520bf52202227" alt=""
案例
所属分支
data:image/s3,"s3://crabby-images/16e70/16e7065b0ca3b885fb9f5652e9aec43764c5de30" alt=""