XML布局 参考
android:text
Dart
<TextView
android:id="@+id/textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Android Java TextView"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
data:image/s3,"s3://crabby-images/88802/88802903579a946be14a06b66fbd4c95a766b8d1" alt=""
android:textSize
Dart
<TextView
android:id="@+id/textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Android Java TextView"
android:textSize="28sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
data:image/s3,"s3://crabby-images/3308e/3308e120efdfac294537591d8614a01a9bc1233f" alt=""
android:textStyle
Dart
<TextView
android:id="@+id/textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Android Java TextView"
android:textStyle="bold"
android:textSize="28sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
data:image/s3,"s3://crabby-images/27933/279338f682a02f04781b8dd3acb484b4d0f755c9" alt=""
文本显示一行
Dart
<TextView
android:id="@+id/textview"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:text="Android Java TextView Android Java TextView Android Java TextView"
android:textStyle="bold"
android:textSize="28sp"
android:maxLines="1"
android:ellipsize="end"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
data:image/s3,"s3://crabby-images/57e5d/57e5d33944377db90832f0ef2d0ae62359edcb3d" alt=""
Compose 布局 参考
build.gradle下面配置
导入依赖包:
Dart
import androidx.compose.runtime.Composable
import androidx.compose.ui.tooling.preview.Preview
Dart
class MainComposeActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent { showTextView() }
}
}
@Preview
@Composable
private fun showTextView() {
Text(text = "Android Compose TextView",
fontSize = 28.sp,
fontStyle = FontStyle.Italic)
}
data:image/s3,"s3://crabby-images/b1d26/b1d26f4fa71556780ed1ac30979ff285726489aa" alt=""
解决无法预览Preview
通过 Android Studio 工具执行 Invalidate Caches
data:image/s3,"s3://crabby-images/b28e5/b28e52d8d2f808343690fcc46c1d86d5afc74e93" alt=""
文本显示一行
Dart
Text(
text = "Android Compose TextView Android Compose TextView Android Compose TextView ",
fontSize = 28.sp,
fontStyle = FontStyle.Italic,
maxLines = 1,
overflow = TextOverflow.Ellipsis
)
data:image/s3,"s3://crabby-images/b4d85/b4d85b1fb55695555e3bb3b6c9e03a32533604d1" alt=""
Flutter 布局 参考
Dart
Text(
'Flutter Dart TextView',
style: TextStyle(fontSize: 12.sp, fontWeight: FontWeight.bold),
),
data:image/s3,"s3://crabby-images/b3bfa/b3bfaf3ca27ea60f1b431f5d0b6799816521e7ef" alt=""
data:image/s3,"s3://crabby-images/10ace/10acec919abdf2776dad9c3299e9bc5f0c18e05a" alt=""
显示一行文本
Dart
Text(
'Flutter Dart TextView Flutter Dart TextView Flutter Dart TextView ',
maxLines: 1,
overflow: TextOverflow.ellipsis,
style: TextStyle(
fontSize: 28.sp,
fontWeight: FontWeight.bold,
),
)
data:image/s3,"s3://crabby-images/b0521/b052122e5a5df27445d7c5139f1f926b55e81a9a" alt=""
HarmonyOS布局 参考
DevEco Studio版本
data:image/s3,"s3://crabby-images/4bd08/4bd08dfbad498987808e9b3d31fc961430bfce26" alt=""
显示文本
Dart
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
data:image/s3,"s3://crabby-images/7eb8a/7eb8acb22e38852e09f181038fd8e2d6acd7ee9f" alt=""
预览Previewer 问题
data:image/s3,"s3://crabby-images/f67de/f67de1effbbdc02ffcca6cb80684a885531327c7" alt=""
显示一行文本
Dart
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
.maxLines(1)
.textOverflow({overflow:TextOverflow.Ellipsis})
data:image/s3,"s3://crabby-images/1a885/1a885287512b35faebbda53a20bbaf8de9485048" alt=""
IOS Object-c 布局 参考
显示一行文本
objectivec
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
UITextView* textView = [[UITextView alloc]initWithFrame:CGRectMake(0, 100, 320, 300)];
NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc]
initWithString:@"IOS Object-c TextView IOS Object-c TextView IOS Object-c TextView IOS Object-c TextView"];
[attributedString addAttribute:NSFontAttributeName value:[UIFont boldSystemFontOfSize:28.0] range:NSMakeRange(0, attributedString.length)];
textView.textContainer.maximumNumberOfLines = 1;
textView.textContainer.lineBreakMode = NSLineBreakByTruncatingTail;
textView.attributedText = attributedString;
[self.view addSubview:textView];
}
@end
data:image/s3,"s3://crabby-images/d7c61/d7c610240767406673c6d17a3c20b22f6f4ca512" alt=""
data:image/s3,"s3://crabby-images/73003/7300371fbc4c8304aad3b1a4393d71a5b2c90553" alt=""
IOS Swift 布局 参考
显示一行文本
objectivec
import UIKit
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
let attributedString = NSMutableAttributedString(string: "Ios Swift TextView Ios Swift TextView Ios Swift TextView Ios Swift TextView")
attributedString.addAttribute(NSAttributedString.Key.font, value: UIFont.boldSystemFont(ofSize: 28.0), range: NSRange(location: 0, length: attributedString.length))
let textView = UITextView(frame: CGRect(x: 0, y: 100, width: 320, height: 300))
textView.attributedText = attributedString
textView.textContainer.maximumNumberOfLines = 1;
textView.textContainer.lineBreakMode = .byTruncatingTail
self.view.addSubview(textView)
}
}
data:image/s3,"s3://crabby-images/eefde/eefde31cb9b21c37c69f51b5f9cd8ff0117cc7ec" alt=""
data:image/s3,"s3://crabby-images/729a2/729a202a95e5c9f73c942ec76b63efc951ac2ef8" alt=""
React Native 布局 参考
显示一行文本
Dart
import React from 'react';
import {AppRegistry, StyleSheet, Text, View} from 'react-native';
import {name as appName} from './app.json';
const ReactNativeTextView = () => {
return (
<View style={styles.container}>
<Text numberOfLines={1} ellipsizeMode="tail" style={styles.hello}>
React Native TextView React Native TextView
</Text>
</View>
);
};
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
},
hello: {
fontSize: 28.0,
textAlign: 'center',
margin: 10,
},
});
AppRegistry.registerComponent(
appName,
() => ReactNativeTextView,
);
data:image/s3,"s3://crabby-images/beae5/beae5386f91c36cf565fd5a17ee3f6f3bccb4fb2" alt=""
设置淘宝npm镜像
Dart
npm config set registry https://registry.npmmirror.com/
检查当前使用的镜像
Dart
npm config get registry
Cannot find module 'react-scripts/package.json'
Dart
执行如下命令:
npm install --save react-scripts
data:image/s3,"s3://crabby-images/51a17/51a170a5da9f7c68be2aef1897fb955d2db92c96" alt=""
执行 export 配置环境
Dart
export JAVA_HOME= Java环境变量安装路径
例如 :
data:image/s3,"s3://crabby-images/9e140/9e140a3ea5d16db878339f42fe162e5ea5d813df" alt=""
修改gradle镜像路径
修改成 阿里云镜像
data:image/s3,"s3://crabby-images/654ad/654addc97da71c4a4cb5b82c4a8a39655449ddd7" alt=""
运行到安卓平台
采用 npx react-native run-android 或npm start 运行
data:image/s3,"s3://crabby-images/3ce4f/3ce4f2e7d94c3a08c0ec0bdf81a7541e15a336a7" 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/05cc8/05cc8ec89d3faab83220bb31835d702ad60c0572" alt=""
data:image/s3,"s3://crabby-images/243ff/243ff7513a441e7b88b23394f0b440fd589f6da5" alt=""
案例
所属分支
data:image/s3,"s3://crabby-images/83ba1/83ba1fd356b116f8f9d8eb4fbd86c55926318680" alt=""