java安卓显示文字,Android之UI学习篇一:TextVeiw如何显示丰富的文本

那么究竟如何来让我们的TextView显示的内容更加丰富多彩呢,这一篇来跟大家一起探讨一下:

首先呢,大家要知道的是,我们网页里能够显示多样性的文字,都归功与HMTL标签对吧,其实在Android的TextView中也预定了一些类似HTML的标签,通过标签可以使TextView控件显示不同颜色、大小、字体的文字:

:设置颜色和字体

:设置大号

:设置小号

\:分别是斜体和粗体

:链接地址

:插入图片

使用这些标签可以用Html.fromHtml方法将这些标签的字符串转换成Charsequence对象,然后再TextView中进行设置;

如果想在显示的文本中将URL地址、邮箱地址、电话产生超链接的效果,可以使用android:autoLink来设置,该属性的规则如下:

属性值                 描述

None          不匹配任何链接(默认)

web                      网址

email                   邮箱

phone               电话号码

map                  匹配映射网址

all                      匹配所有链接

下面通过一个实例来讲解一下如何灵活使用这些标签:

实现的丰富文字TextView截图:

75fb38e67f49755076e3c9579bba9514.png

点击"百度"文字链接之后,打开了浏览器并跳转到了百度网址,截图如下:

cdd65ee1908a47772a71fa7b9456a999.png

点击电话号码"+86148998943"之后弹出了拨打电话的界面,截图:

62418265123d4c615b762a9fd43b2fb5.png

代码如下:

TextViewActivity.java

public class Android_TextviewActivity extends Activity {

private TextView textView1;

private TextView textView2;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

/*

* 实现在TextView中显示URL、不同大小、字体、颜色的文本

* */

textView1=(TextView)findViewById(R.id.textview1);

textView2=(TextView)findViewById(R.id.textview2);

//添加一段html的标示

String html="I love Android
";

html+=" I love Android 

";

html+="百度";

CharSequence charSequence=Html.fromHtml(html);

textView1.setText(charSequence);

//点击的时候产生超链接

textView1.setMovementMethod(LinkMovementMethod.getInstance());

String text="我的URL:http://www.sina.com\n";  //这里的\n是换行符

text+="我的Email:mrwujay@163.com\n";

text+="我的电话:+86148998933";

textView2.setText(text);

textView2.setMovementMethod(LinkMovementMethod.getInstance());

}

}

main.xml

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="vertical" >

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:id="@+id/textview1"

android:padding="20sp"/>

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:id="@+id/textview2"

android:padding="20sp"

android:autoLink="all"

android:textSize="20sp"

android:text="@string/link_text"/>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
鸿蒙OS是华为推出的一款操作系统,其Java UI框架是Harmony UI Kit,可以用来开发鸿蒙应用程序的UI界面。下面是一个简单的登录页面设计示例: ```java import ohos.aafwk.ability.AbilitySlice; import ohos.aafwk.content.Intent; import ohos.agp.components.*; public class LoginAbilitySlice extends AbilitySlice implements Component.ClickedListener { private Text usernameText, passwordText; private TextField usernameField, passwordField; private Button loginButton, registerButton; @Override public void onStart(Intent intent) { super.onStart(intent); super.setUIContent(ResourceTable.Layout_ability_login); usernameText = (Text) findComponentById(ResourceTable.Id_username_text); passwordText = (Text) findComponentById(ResourceTable.Id_password_text); usernameField = (TextField) findComponentById(ResourceTable.Id_username_field); passwordField = (TextField) findComponentById(ResourceTable.Id_password_field); loginButton = (Button) findComponentById(ResourceTable.Id_login_button); registerButton = (Button) findComponentById(ResourceTable.Id_register_button); loginButton.setClickedListener(this); registerButton.setClickedListener(this); } @Override public void onClick(Component component) { if (component == loginButton) { String username = usernameField.getText(); String password = passwordField.getText(); // 处理登录逻辑 } else if (component == registerButton) { // 处理注册逻辑 } } } ``` 这个程序使用XML布局文件`ability_login.xml`来定义登录页面的UI界面。在`LoginAbilitySlice`类中,我们可以通过`findComponentById`方法来获取XML布局文件中定义的UI组件,并添加点击事件监听器来处理登录和注册逻辑。 下面是`ability_login.xml`的示例代码: ```xml <?xml version="1.0" encoding="utf-8"?> <DirectionalLayout xmlns:ohos="http://schemas.huawei.com/res/ohos" ohos:height="match_parent" ohos:width="match_parent" ohos:orientation="vertical"> <Text ohos:id="$+id:username_text" ohos:width="match_parent" ohos:height="wrap_content" ohos:text="用户名" ohos:text_size="30fp" ohos:padding="16fp"/> <TextField ohos:id="$+id:username_field" ohos:width="match_parent" ohos:height="70fp" ohos:hint="请输入用户名" ohos:margin="16fp"/> <Text ohos:id="$+id:password_text" ohos:width="match_parent" ohos:height="wrap_content" ohos:text="密码" ohos:text_size="30fp" ohos:padding="16fp"/> <TextField ohos:id="$+id:password_field" ohos:width="match_parent" ohos:height="70fp" ohos:hint="请输入密码" ohos:margin="16fp" ohos:input_type="password"/> <Button ohos:id="$+id:login_button" ohos:width="match_parent" ohos:height="80fp" ohos:text="登录" ohos:margin="16fp"/> <Button ohos:id="$+id:register_button" ohos:width="match_parent" ohos:height="80fp" ohos:text="注册" ohos:margin="16fp"/> </DirectionalLayout> ``` 在这个XML布局文件中,我们使用了`DirectionalLayout`来布局UI组件,并设置了每个UI组件的属性,如文本、宽度、高度、提示文本、边距和输入类型等。 需要注意的是,鸿蒙OS的Java UI框架与AndroidUI框架有所不同,开发者需要根据鸿蒙OS的API文档来了解具体的UI组件和属性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值