Android

 1 android:textAppearance
 2 设置文字外观。如“?android:attr/textAppearanceLargeInverse
 3 ”这里引用的是系统自带的一个外观,?表示系统是否有这种外观,否则使用默认的外观。可设置的值如下:textAppearanceButton/textAppearanceInverse/textAppearanceLarge/textAppearanceLargeInverse/textAppearanceMedium/textAppearanceMediumInverse/textAppearanceSmall/textAppearanceSmallInverse
 4
 5 textView.getPaint().setFlags(Paint. UNDERLINE_TEXT_FLAG ); //下划线
 6
 7 textView.getPaint().setAntiAlias(true);//抗锯齿
 8
 9 textview.getPaint().setFlags(Paint. STRIKE_THRU_TEXT_FLAG); //中划线
10
11 setFlags(Paint. STRIKE_THRU_TEXT_FLAG|Paint.ANTI_ALIAS_FLAG);  // 设置中划线并加清晰
12
13 textView.getPaint().setFlags(0);  // 取消设置的的划线

编辑器中的划线

一条线:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle"> 

    <stroke android:width="1dp" android:color="#DADCDE"></stroke>
    <solid android:color="#fff"></solid>
    <corners android:radius="0dip" />

</shape>

在布局文件中设置textview的autolink及其类型,这时textivew上会显示link的颜色,并且文字下面会有一条下划线,表示可以点击。而在我们在点击textview时,应用将根据我们所设置的类型跳转到对应的界面。但是有时,我们因界面需求,需要去掉界面上显示的下划线,并保持功能不变。

如果已经设置了autolink,那么在textview当中再去设置TextPaint为无下划线是无效的,我们可以看URLSpan所继承的类ClickableSpan类的源码,如下:

[java] view plain copy

  1. public abstract class ClickableSpan extends CharacterStyle implements UpdateAppearance {
  2. /**
  3. * Performs the click action associated with this span.
  4. */
  5. public abstract void onClick(View widget);
  6. /**
  7. * Makes the text underlined and in the link color.
  8. */
  9. @Override
  10. public void updateDrawState(TextPaint ds) {
  11. ds.setColor(ds.linkColor);
  12. ds.setUnderlineText(true);
  13. }
  14. }

可以看到在这里它是重新设置为有下划线的。

所以要解决这个问题,就只有再设置一个没有下划线的Spannable对象。

首先,继承一个CharacterStyle或其已实现的子类,重写updateDrawState方法,代码如下:

[java] view plain copy

  1. /*
  2. * Date: 14-9-4
  3. * Project: Access-Control-V2
  4. */
  5. package cn.irains.access.v2.common;
  6. import android.text.TextPaint;
  7. import android.text.style.UnderlineSpan;
  8. /**
  9. * 无下划线的Span
  10. * Author: msdx ([email protected])
  11. * Time: 14-9-4 上午10:43
  12. */
  13. public class NoUnderlineSpan extends UnderlineSpan {
  14. @Override
  15. public void updateDrawState(TextPaint ds) {
  16. ds.setColor(ds.linkColor);
  17. ds.setUnderlineText(false);
  18. }
  19. }

然后在textview设置了内容之后,调用以下的代码,设置一个span:

[java] view plain copy

  1. NoUnderlineSpan mNoUnderlineSpan = new NoUnderlineSpan();
  2. if (textview.getText() instanceof Spannable) {
  3. Spannable s = (Spannable) textview.getText();
  4. s.setSpan(mNoUnderlineSpan, 0, s.length(), Spanned.SPAN_MARK_MARK);
  5. }

如果你是在listview中使用,并且用了holder,则span对象创建一个就可以了,然后在调用了setText之后再重新设置一遍span。这样textview在界面上就不会有下划线了,但却保留着autolink的功能。

Android Studio中的EditText控件使用详解

一:新建HelloEditText工程

创建设置如下:

  1. Project name: HelloEditText
  2. Build Target :android 2.2
  3. Application name:HelloEditText
  4. Package name:com.flysnow
  5. create Activity: HelloEditText
  6. min SDK 8

这时候运行还看不到EditText,因为我们还没有加上,修改main.xml如下:

Xml代码  

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <EditText
  8. android:id="@+id/edit_text"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:text="这是一个EditText"/>
  12. </LinearLayout>

这里添加了一个id为"edit_text"的EditText,设置默认显示为本为“这是一个EditText”。。运行效果如下:

二:EditText简介

EditText是一个非常重要的组件,可以说它是用户和Android应用进行数据传输窗户,有了它就等于有了一扇和Android应用传输的门,通过它用户可以把数据传给Android应用,然后得到我们想要的数据。

EditText是TextView的子类,所以TextView的方法和特性同样存在于EditText中,具体的TextView的介绍可以参考上一节Android系列教程之六:TextView小组件的使用--附带超链接和跑马灯效果

三:长度和空白提示文字,提示文字颜色,是否可编辑等

EditText有一些属性可以设置EditText的特性,比如最大长度,空白提示文字等。

  1. 有时候我们有一些特属的需要,要求只能在EditText中输入特定个数的字符,比如身份证号、手机号吗等。这时候就可以通过android:maxLength属性来设置最大输入字符个数,比如android:maxLength=“4”就表示最多能输入4个字符,再多了就输入不进去了。
  2. 空白提示文字。有时候我们需要说明你定义的这个EditText是做什么用的,比如让输入“用户名”,或者输入“电话号码”等,但是你又不想在EditText前面加一个TextView来说明这是输入“用户名”的,因为这会使用一个TextView,那么怎么办呢?EditText为我们提供了android:hint来设置当EditText内容为空时显示的文本,这个文本只在EditText为空时显示,你输入字符的时候就消失了,不影响你的EditText的文本。。修改main.xml如下: 

    Xml代码  

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:orientation="vertical"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. >
    7. <EditText
    8. android:id="@+id/edit_text"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:maxLength="40"
    12. android:hint="请输入用户名..."/>
    13. </LinearLayout>

    运行应用就会看到如下的效果: 

     看看吧,简洁明了还不用新增一个TextView说明,也不影响用户操作。

  3. 上面列出了空白时的提示文字,有的人说了,我不想要这个灰色的提示文字,和我的应用整体风格不协调,那也行啊,我们可以换颜色,怎么换呢,就是通过android:textColorHint属性设置你想要的颜色。修改main.xml如下:

    Xml代码  

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:orientation="vertical"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. >
    7. <EditText
    8. android:id="@+id/edit_text"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:maxLength="40"
    12. android:hint="请输入用户名..."
    13. android:textColorHint="#238745"/>
    14. </LinearLayout>

    运行程序效果如下: 

     看到了吧,颜色已经变了。。

  4. 还有一个比较实用的功能,就是设置EditText的不可编辑。设置android:enabled="false"可以实现不可编辑,可以获得焦点。这时候我们看到EditText和一个TextView差不多: 
  5. 实现类似html中Textarea的文本域。在Android中没有专门的文本域组件,但是可以通过设置EditText的高来实现同样的文本域功能。修改main.xml如下: 

    Xml代码  

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:orientation="vertical"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. >
    7. <EditText
    8. android:id="@+id/edit_text"
    9. android:layout_width="fill_parent"
    10. android:layout_height="200dip"/>
    11. </LinearLayout>

    运行程序效果如下: 

四:输入特殊格式的字符

在我们开发程序的时候不免会输入一些特属个数的字符,比如密码(输入框的字符要加密显示),电话号码(比如数字和-),数字等,这些都算是一些特属格式的字符,强大的EditText同样为我们提供了输入这些特属格式字符的设置。

  1. 密码文本框。密码输入也是Android应用常用的功能,通过配置EditText的android:password="true"就可以实现这一密码输入功能,修改main.xml如下:

    Xml代码  

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:orientation="vertical"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. >
    7. <EditText
    8. android:id="@+id/edit_text"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:password="true"/>
    12. </LinearLayout>

    运行效果如下: 

     可以看到我们输入的字符已经被“.”这样的掩码所代替。

  2. 手机中发短信打电话是必不可少的,所以用于专门输入电话号码的文本框也是大有用途,有了他我们对是否是电话号码的校验就容易的多了(因为字符是正确的,只要校验格式 ).通过设置android:phoneNumber="true"就可以把EditText变成只接受电话号码输入的文本框,连软键盘都已经变成拨号专用软键盘了,所以不用再担心输入其他字符了。修改main.xml如下: 

    Xml代码  

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:orientation="vertical"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. >
    7. <EditText
    8. android:id="@+id/edit_text"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:phoneNumber="true"/>
    12. </LinearLayout>

    运行程序效果如下: 

     注意看软键盘,已经变成拨号专用的啦.

  3. 有时候我们只想输入数字,不想输入字母,EditText为我们提供了android:numeric来控制输入的数字类型,一共有三种分别为integer(正整数)、signed(带符号整数)和decimal(浮点数)。这里以signed类型的为例,修改main.xml如下: 

    Xml代码  

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:orientation="vertical"
    4. android:layout_width="fill_parent"
    5. android:layout_height="fill_parent"
    6. >
    7. <EditText
    8. android:id="@+id/edit_text"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:numeric="signed"/>
    12. </LinearLayout>

    运行效果如下: 

     注意这里的软键盘变成“数字键盘”的变化.

五:为文本指定特定的软键盘类型

前面我们通过指定为电话号码特定格式,然后键盘类型变成了拨号专用的键盘,这个是自动变的,其实我们也可以通过android:inputType来设置文本的类型,让输入法选择合适的软键盘的。。android:inputType有很多类型,这里使用date类型来演示,修改main.xml如下: 

Xml代码  

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <EditText
  8. android:id="@+id/edit_text"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:inputType="date"/>
  12. </LinearLayout>

运行效果如下: 

六:Enter键图标的设置

软键盘的Enter键默认显示的是“完成”文本,我们知道按Enter建表示前置工作已经准备完毕了,要去什么什么啦。比如,在一个搜索中,我们输入要搜索的文本,然后按Enter表示要去搜索了,但是默认的Enter键显示的是“完成”文本,看着不太合适,不符合搜索的语义,如果能显示“搜索”两个字或者显示一个表示搜索的图标多好。事实证明我们的想法是合理的,Android也为我们提供的这样的功能。通过设置android:imeOptions来改变默认的“完成”文本。这里举几个常用的常量值:

  1. actionUnspecified  未指定,对应常量EditorInfo.IME_ACTION_UNSPECIFIED.效果:
  2. actionNone 没有动作,对应常量EditorInfo.IME_ACTION_NONE 效果:
  3. actionGo 去往,对应常量EditorInfo.IME_ACTION_GO 效果:
  4. actionSearch 搜索,对应常量EditorInfo.IME_ACTION_SEARCH 效果: 
  5. actionSend 发送,对应常量EditorInfo.IME_ACTION_SEND 效果:
  6. actionNext 下一个,对应常量EditorInfo.IME_ACTION_NEXT 效果:
  7. actionDone 完成,对应常量EditorInfo.IME_ACTION_DONE 效果:

下面已搜索为例,演示一个实例,修改main.xml如下:

Xml代码  

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <EditText
  8. android:id="@+id/edit_text"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:imeOptions="actionSearch"/>
  12. </LinearLayout>

修改HelloEditText如下:

Java代码  

  1. package com.flysnow;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.view.KeyEvent;
  5. import android.widget.EditText;
  6. import android.widget.TextView;
  7. import android.widget.Toast;
  8. import android.widget.TextView.OnEditorActionListener;
  9. public class HelloEditText extends Activity {
  10. /** Called when the activity is first created. */
  11. @Override
  12. public void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.main);
  15. EditText editText=(EditText)findViewById(R.id.edit_text);
  16. editText.setOnEditorActionListener(new OnEditorActionListener() {
  17. @Override
  18. public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
  19. Toast.makeText(HelloEditText.this, String.valueOf(actionId), Toast.LENGTH_SHORT).show();
  20. return false;
  21. }
  22. });
  23. }
  24. }

运行程序,点击回车(也就是搜索图标软键盘按钮)会显示该actionId.我们上面的每一个设置都会对应一个常量,这里的actionId就是那个常量值。 

七:EditText的取值、全选、部分选择、获取选中文本

下面通过一个例子来演示EditText的取值、全选、部分选择和获取选中文本.main.xml修改如下:

Xml代码  

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <EditText
  8. android:id="@+id/edit_text"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:imeOptions="actionSearch"/>
  12. <Button
  13. android:id="@+id/btn_get_value"
  14. android:text="取值"
  15. android:layout_width="wrap_content"
  16. android:layout_height="wrap_content"/>
  17. <Button
  18. android:id="@+id/btn_all"
  19. android:text="全选"
  20. android:layout_width="wrap_content"
  21. android:layout_height="wrap_content"/>
  22. <Button
  23. android:id="@+id/btn_select"
  24. android:text="从第2个字符开始选择"
  25. android:layout_width="wrap_content"
  26. android:layout_height="wrap_content"/>
  27. <Button
  28. android:id="@+id/btn_get_select"
  29. android:text="获取选中文本"
  30. android:layout_width="wrap_content"
  31. android:layout_height="wrap_content"/>
  32. </LinearLayout>

HelloEditText修改如下:

Java代码  

  1. package com.flysnow;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.text.Editable;
  5. import android.text.Selection;
  6. import android.view.KeyEvent;
  7. import android.view.View;
  8. import android.view.View.OnClickListener;
  9. import android.widget.Button;
  10. import android.widget.EditText;
  11. import android.widget.TextView;
  12. import android.widget.Toast;
  13. import android.widget.TextView.OnEditorActionListener;
  14. /**
  15. * EditText演示
  16. * @author 飞雪无情
  17. * @since 2010-11-29
  18. */
  19. public class HelloEditText extends Activity {
  20. /** Called when the activity is first created. */
  21. @Override
  22. public void onCreate(Bundle savedInstanceState) {
  23. super.onCreate(savedInstanceState);
  24. setContentView(R.layout.main);
  25. final EditText editText=(EditText)findViewById(R.id.edit_text);
  26. //监听回车键
  27. editText.setOnEditorActionListener(new OnEditorActionListener() {
  28. @Override
  29. public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
  30. Toast.makeText(HelloEditText.this, String.valueOf(actionId), Toast.LENGTH_SHORT).show();
  31. return false;
  32. }
  33. });
  34. //获取EditText文本
  35. Button getValue=(Button)findViewById(R.id.btn_get_value);
  36. getValue.setOnClickListener(new OnClickListener() {
  37. @Override
  38. public void onClick(View v) {
  39. Toast.makeText(HelloEditText.this, editText.getText().toString(), Toast.LENGTH_SHORT).show();
  40. }
  41. });
  42. //让EditText全选
  43. Button all=(Button)findViewById(R.id.btn_all);
  44. all.setOnClickListener(new OnClickListener() {
  45. @Override
  46. public void onClick(View v) {
  47. editText.selectAll();
  48. }
  49. });
  50. //从第2个字符开始选择EditText文本
  51. Button select=(Button)findViewById(R.id.btn_select);
  52. select.setOnClickListener(new OnClickListener() {
  53. @Override
  54. public void onClick(View v) {
  55. Editable editable=editText.getText();
  56. Selection.setSelection(editable, 1,editable.length());
  57. }
  58. });
  59. //获取选中的文本
  60. Button getSelect=(Button)findViewById(R.id.btn_get_select);
  61. getSelect.setOnClickListener(new OnClickListener() {
  62. @Override
  63. public void onClick(View v) {
  64. int start=editText.getSelectionStart();
  65. int end=editText.getSelectionEnd();
  66. CharSequence selectText=editText.getText().subSequence(start, end);
  67. Toast.makeText(HelloEditText.this, selectText, Toast.LENGTH_SHORT).show();
  68. }
  69. });
  70. }
  71. /**
  72. * 交换两个索引
  73. * @param start 开始索引
  74. * @param end 结束索引
  75. */
  76. protected void switchIndex(int start, int end) {
  77. int temp=start;
  78. start=end;
  79. end=temp;
  80. }
  81. }
时间: 2024-10-10 05:20:12

Android的相关文章

Android : &lt;com.mobeta.android.dslv.DragSortListView-引用自定义控件包名错误

所谓的包名与命名空间的问题,包名不一致是指与自己工程的package名称不一置, 开始以为是到自定义包名不一置,真是个误区:

android 利用 aapt 解析 apk 的应用名称 包名 版本号 权限等信息

在上传各大市场时发现 apk 上传后能自动解析出应用名称.包名.版本号.使用权限等信息,所以就研究了一下 1 直接解压 apk 解析  AndroidManifest.xml 是不行的,因为 apk 打包时 AndroidManifest.xml 文件被压缩混淆了. 2 主要有两种实现方式 1) 通过 aapt (android asset packaging tool) aapt 是打包.更新资源的一个工具,可以解析出 apk 的资源信息 2) apktool 著名的反编译工具,先反编译出 A

android如何查找安装的apk app的包名和Activity

http://www.51testing.com/html/01/610901-864955.html 解决办法:a.有源码的情况,找到AndroidManifest.xml,找到android.intent.category.LAUNCHER关键字,就能找到需要的Activity包名在这里看;<manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.chnM

Android 利用 aapt 解析 apk 得到应用名称 包名 版本号 权限等信息

转:http://www.cnblogs.com/lesliefang/p/3864756.html 在上传各大市场时发现 apk 上传后能自动解析出应用名称.包名.版本号.使用权限等信息,所以就研究了一下 1 直接解压 apk 解析  AndroidManifest.xml 是不行的,因为 apk 打包时 AndroidManifest.xml 文件被压缩混淆了. 2 主要有两种实现方式 1) 通过 aapt (android asset packaging tool) aapt 是打包.更新

Android 编程下如何修改 jar 文件的包名

首先我们要说说为什么要修改 jar 文件的包名,jar 包我们会非常高频率的使用,尤其是用一些其他三方库的时候,往往把 java 代码打包成 jar 文件,方便项目依赖使用.笔者在开发过程中遇到过一些问题,是由于 jar 文件里面的包名和项目或者运行时环境的引用文件包名上存在冲突导致的,这时候我们修改 jar 文件的包名是一个比较快速有效的解决办法.举两个例子,是笔者亲身经历的两个情况. Gson库:这个相信很多人都在使用,但是直接导入 gson 的 jar 包,在 HTC Desire HD

android 自动化压力测试-monkey 2 获取程序包名

monkey 1 中我们写到: C:\Users\chenshan>adb shell [email protected]-T20:/ $ monkey -p cn.emoney.acg -v 500 说明:-p :指定被测试apk,主Activity(第一个启动的Activity)所在的包名(我问的开发) -v :指定测试的次数 也可以通过如下方法来获取机器中所有的包名: #adb shell #su #cd data/data #ls 如果提示:opendir failed, Permiss

迁移eclipse的Android项目到Android studio平台的注意事项

整体要注意的地方 先说明一下整体需要注意的地方 1在Android studio建立项目的时候,要注意包名和原来的完全一致,不然会有很多需要改动. 2依赖的jar一定一定要找齐,不然新建项目引用不到,要么重新找包,严重的话,那部分代码要重写,影响很恶劣... 3Android studio的编译器有点蠢.引用了多余的包编译会通过,但是debug会报错.此事要重点排查android.support:appcompat-v7和com.android.support:support-v4包.这2个包很

20_Android中apk安装器,通过WebView来load进一个页面,Android通知,程序退出自动杀死进程,通过输入包名的方式杀死进程

?? 场景:实现安装一个apk应用程序的过程.界面如下: 编写如下应用,应用结构如下: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_heigh

Android项目中包名的修改

通常修改包名时会造成R文件错误,并且有时带有原因不明的Manifest文件中多处文本混乱. 所以,将目前认为最为简洁方便的修改包名流程记录如下: 假设我们目前的包名为com.pepper.util,我们将要把包名修改为com.pp.util 1.点击项目右击-->Android Tools-->rename application package:修改好包名-->点击OK-->点击finish:Launch configuration update-->点击Yes 2.假设你

Android项目中包名的改动

通常改动包名时会造成R文件错误,而且有时带有原因不明的Manifest文件里多处文本混乱. 所以,将眼下觉得最为简洁方便的改动包名流程记录例如以下: 如果我们眼下的包名为com.pepper.util,我们将要把包名改动为com.pp.util 1.点击项目右击-->Android Tools-->rename application package:改动好包名-->点击OK-->点击finish:Launch configuration update-->点击Yes 2.如