Android textView字体自定义结合HTml
来源:互联网 发布:和msqrd一样的软件 编辑:程序博客网 时间:2024/06/05 19:47
可以使用setTypeface(Typeface)方法来设置文本框内文本的字体,而android的Typeface又使用TTF字体文件来设置字体
所以,我们可以在程序中放入TTF字体文件,在程序中使用Typeface来设置字体:第一步,在assets目录下新建fonts目录,把TTF字体文件放到这里。第二步,程序中调用:
TextViewtv = (TextView)findViewById(R.id.textView);
AssetManagermgr=getAssets();//得到AssetManager
Typefacetf=Typeface.createFromAsset(mgr, "fonts/mini.TTF");//根据路径得到Typeface
tv.setTypeface(tf);//设置字体
效果如下图所示:
2. 显示多种颜色的字
Android支持html格式的字符串,通过调用Html.fromHtml(str)方法可以转换html格式的字符串str。
示例如下:
StringtextStr1 = "<font color=\"#ffff00\">如果有一天,</font><br>";
StringtextStr2 = "<font color=\"#00ff00\">我厌倦了这里,</font><br>";
StringtextStr3 = "<font color=\"#ff00ff\">我会乘着梦,</font><br>";
StringtextStr4 = "<font color=\"#00ffff\">飞向那个属于自己的<br>世界……</font><br>";
tv.setText(Html.fromHtml(textStr1+textStr2+textStr3+textStr4));
运行后效果如下:
3. 字体加粗
在xml布局文件中使用android:textStyle=”bold”可以将英文设置成粗体,但是不能将中文设置成粗体,将中文设置成粗体的方法是:使用TextPaint的仿“粗体”设置setFakeBoldText为true。示例代码如下:
tv.getPaint().setFakeBoldText(true);
效果如下:
4. 添加阴影
在xml布局文件中使用一系列android:shadowXXX属性可添加设置阴影。具体为:shadowColor设置阴影颜色;shadowDx设置阴影水平偏移量;shadowDy设置阴影垂直偏移量;shadowRadius设置阴影半径。
示例代码:
android:shadowColor="#ffffff"
android:shadowDx="15.0"
android:shadowDy="5.0"
android:shadowRadius="2.5"
显示效果如下:
5. 插入图片
插入图片有两种方法,第一种方法就是用上面说的html格式的字符串,不过转换稍微有些麻烦。需要用到ImageGetter类来对图片的src属性进行转换。示例代码如下:
StringimgStr = "<img src=\""+R.drawable.sidai+"\"/>";
Html.ImageGetterimageGetter = new Html.ImageGetter() {
public Drawable getDrawable(Stringarg0) {
// TODO Auto-generated methodstub
int id =Integer.parseInt(arg0);
Drawable draw =getResources().getDrawable(id);
draw.setBounds(10, 10, 228,300);
return draw;
}
};
tv.append(Html.fromHtml(imgStr,imageGetter,null));
第二种方法是使用xml布局文件中一系列android:drawableXXX属性来实现插入图片。具体为:drawableBottom是在文本框内文本的底端绘制指定图像;drawableLeft是在文本框内文本的左边绘制指定图像;drawableRight是在文本框内文本的右边绘制指定图像;drawableTop是在文本框内文本的顶端绘制指定图像;drawablePadding设置文本框内文本与图像之间的间距。示例代码:
android:drawableBottom=”@drawable/sidai”
插入图片后的显示效果如下:
摘自 北京大学-Google Android实验室
android设置textView属性
字间距
textView有一个属性android:textScaleX是调节字间距的,它的值是一个float型。查看源代码,默认textView 此属性是使用的是:
android.internal.R.styleable.TextView_textScaleX
setTextScaleX(a.getFloat(attr, 1.0f));
行间距
Android系统中TextView默认显示中文时会比较紧凑,不是很美观。为了让每行保持一定的行间距,可以设置属性android:lineSpacingExtra或android:lineSpacingMultiplier。
关于Android下TextView中文换行问题,可查看Android自定义view-文本自动换行。
1、android:lineSpacingExtra
设置行间距,如”3dp”。
2、android:lineSpacingMultiplier
设置行间距的倍数,如”1.2″。
参考代码:
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:lineSpacingExtra="3dp"
android:lineSpacingMultiplier="1.5"
android:textStyle="bold" />
设置部分文字背景高亮显示:
- public class HighLightActivity extends Activity {
- String strs="我的心太乱了,给我点空白。";
- TextView textview;
- int start =3;
- int end = 5;
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.high_light);
- textview=(TextView)findViewById(R.id.textview);
- SpannableStringBuilder style=new SpannableStringBuilder(strs);
- style.setSpan(new BackgroundColorSpan(Color.RED),start,end,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
- textview.setText(style);
- }
- }
同时设置文字和背景高亮显示:
- package com.justel.contact;
- import android.app.Activity;
- import android.graphics.Color;
- import android.os.Bundle;
- import android.text.Spannable;
- import android.text.SpannableStringBuilder;
- import android.text.style.BackgroundColorSpan;
- import android.text.style.ForegroundColorSpan;
- import android.widget.TextView;
- public class HighLightActivity extends Activity {
- String strs="我的心太乱了,给我点空白。";
- TextView textview;
- int start =3;
- int end = 5;
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.high_light);
- textview=(TextView)findViewById(R.id.textview);
- SpannableStringBuilder style=new SpannableStringBuilder(strs);
- style.setSpan(new BackgroundColorSpan(Color.RED),start,end,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
- style.setSpan(new ForegroundColorSpan(Color.RED),7,9,Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
- textview.setText(style);
- }
- }
- package com.justel.contact;
- import android.app.Activity;
- import android.graphics.Color;
- import android.os.Bundle;
- import android.text.Spannable;
- import android.text.SpannableStringBuilder;
- import android.text.style.BackgroundColorSpan;
- import android.text.style.ForegroundColorSpan;
- import android.widget.TextView;
- public class HighLightActivity extends Activity {
- String strs="我的心太乱了,给我点空白。";
- TextView textview;
- int start =3;
- int end = 5;
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.high_light);
- textview=(TextView)findViewById(R.id.textview);
- SpannableStringBuilder style=new SpannableStringBuilder(strs);
- style.setSpan(new BackgroundColorSpan(Color.RED),start,end,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
- style.setSpan(new ForegroundColorSpan(Color.RED),7,9,Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
- textview.setText(style);
1、半角字符与全角字符混乱所致:这种情况一般就是汉字与数字、英文字母混用
解决方法一:
将textview中的字符全角化。即将所有的数字、字母及标点全部转为全角字符,使它们与汉字同占两个字节,这样就可以避免由于占位导致的排版混乱问题了。 半角转为全角的代码如下,只需调用即可。
- public static String ToDBC(String input) {
- char[] c = input.toCharArray();
- for (int i = 0; i< c.length; i++) {
- if (c[i] == 12288) {
- c[i] = (char) 32;
- continue;
- }if (c[i]> 65280&& c[i]< 65375)
- c[i] = (char) (c[i] - 65248);
- }
- return new String(c);
- }
解决方法二:
去除特殊字符或将所有中文标号替换为英文标号。利用正则表达式将所有特殊字符过滤,或利用replaceAll()将中文标号替换为英文标号。则转化之后,则可解决排版混乱问题。
- // 替换、过滤特殊字符
- public static String StringFilter(String str) throws PatternSyntaxException{
- str=str.replaceAll("【","[").replaceAll("】","]").replaceAll("!","!");//替换中文标号
- String regEx="[『』]"; // 清除掉特殊字符
- Pattern p = Pattern.compile(regEx);
- Matcher m = p.matcher(str);
- return m.replaceAll("").trim();
- }
2、TextView在显示中文的时候标点符号不能显示在一行的行首和行尾,如果一个标点符号刚好在一行的行尾,该标点符号就会连同前一个字符跳到下一行显示。
解决方法:在标点符号后加一个空格。
3、一个英文单词不能被显示在两行中( TextView在显示英文时,标点符号是可以放在行尾的,但英文单词也不能分开 )。
4、如果要两行对其的显示效果:有两种方法
方法一:
修改Android源代码;将frameworks/base/core/java/android/text下的StaticLayout.java文件中的如下代码:
- if (c == ' ' || c == '/t' ||
- ((c == '.' || c == ',' || c == ':' || c == ';') &&
- (j - 1 < here || !Character.isDigit(chs[j - 1 - start])) &&
- (j + 1 >= next || !Character.isDigit(chs[j + 1 - start]))) ||
- ((c == '/' || c == '-') &&
- (j + 1 >= next || !Character.isDigit(chs[j + 1 - start]))) ||
- (c >= FIRST_CJK && isIdeographic(c, true) &&
- j + 1 < next && isIdeographic(chs[j + 1 - start], false))) {
- okwidth = w;
- ok = j + 1;
- if (fittop < oktop)
- oktop = fittop;
- if (fitascent < okascent)
- okascent = fitascent;
- if (fitdescent > okdescent)
- okdescent = fitdescent;
- if (fitbottom > okbottom)
- okbottom = fitbottom;
- }
去掉就可以了。去掉后标点符号可以显示在行首和行尾,英文单词也可以被分开在两行中显示。
方法二:
自定义View显示文本
网上就有达人采用自定义View来解决这个问题,我做了实验并总结了一下:
自定义View的步骤:
1)继承View类或其子类,例子继承了TextView类;
2)写构造函数,通过XML获取属性(这一步中可以自定义属性,见例程);
3)重写父类的某些函数,一般都是以on开头的函数,例子中重写了onDraw()和onMeasure()函数;
=========================CYTextView.java=============================
- public class CYTextView extends TextView {
- public static int m_iTextHeight; //文本的高度
- public static int m_iTextWidth;//文本的宽度
- private Paint mPaint = null;
- private String string="";
- private float LineSpace = 0;//行间距
- public CYTextView(Context context, AttributeSet set)
- {
- super(context,set);
- TypedArray typedArray = context.obtainStyledAttributes(set, R.styleable.CYTextView);
- int width = typedArray.getInt(R.styleable. CY TextView_textwidth, 320);
- float textsize = typedArray.getDimension(R.styleable. CY TextView_textSize, 24);
- int textcolor = typedArray.getColor(R.styleable. CY TextView_textColor, -1442840576);
- float linespace = typedArray.getDimension(R.styleable. CY TextView_lineSpacingExtra, 15);
- int typeface = typedArray.getColor(R.styleable. CY TextView_typeface, 0);
- typedArray.recycle();
- //设置 CY TextView的宽度和行间距www.linuxidc.com
- m_iTextWidth=width;
- LineSpace=linespace;
- // 构建paint对象
- mPaint = new Paint();
- mPaint.setAntiAlias(true);
- mPaint.setColor(textcolor);
- mPaint.setTextSize(textsize);
- switch(typeface){
- case 0:
- mPaint.setTypeface(Typeface.DEFAULT);
- break;
- case 1:
- mPaint.setTypeface(Typeface.SANS_SERIF);
- break;
- case 2:
- mPaint.setTypeface(Typeface.SERIF);
- break;
- case 3:
- mPaint.setTypeface(Typeface.MONOSPACE);
- break;
- default:
- mPaint.setTypeface(Typeface.DEFAULT);
- break;
- }
- }
- @Override
- protected void onDraw(Canvas canvas)
- {
- super.onDraw(canvas);
- char ch;
- int w = 0;
- int istart = 0;
- int m_iFontHeight;
- int m_iRealLine=0;
- int x=2;
- int y=30;
- Vector m_String=new Vector();
- FontMetrics fm = mPaint.getFontMetrics();
- m_iFontHeight = (int) Math.ceil(fm.descent - fm.top) + (int)LineSpace;//计算字体高度(字体高度+行间距)
- for (int i = 0; i < string.length(); i++)
- {
- ch = string.charAt(i);
- float[] widths = new float[1];
- String srt = String.valueOf(ch);
- mPaint.getTextWidths(srt, widths);
- if (ch == '/n'){
- m_iRealLine++;
- m_String.addElement(string.substring(istart, i));
- istart = i + 1;
- w = 0;
- }else{
- w += (int) (Math.ceil(widths[0]));
- if (w > m_iTextWidth){
- m_iRealLine++;
- m_String.addElement(string.substring(istart, i));
- istart = i;
- i--;
- w = 0;
- }else{
- if (i == (string.length() - 1)){
- m_iRealLine++;
- m_String.addElement(string.substring(istart, string.length()));
- }
- }
- }
- }
- m_iTextHeight=m_iRealLine*m_iFontHeight+2;
- canvas.setViewport(m_iTextWidth, m_iTextWidth);
- for (int i = 0, j = 0; i < m_iRealLine; i++, j++)
- {
- canvas.drawText((String)(m_String.elementAt(i)), x, y+m_iFontHeight * j, mPaint);
- }
- }
- protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
- {
- int measuredHeight = measureHeight(heightMeasureSpec);
- int measuredWidth = measureWidth(widthMeasureSpec);
- this.setMeasuredDimension(measuredWidth, measuredHeight);
- this.setLayoutParams(new LinearLayout.LayoutParams(measuredWidth,measuredHeight));
- super.onMeasure(widthMeasureSpec, heightMeasureSpec);
- }
- private int measureHeight(int measureSpec)
- {
- int specMode = MeasureSpec.getMode(measureSpec);
- int specSize = MeasureSpec.getSize(measureSpec);
- // Default size if no limits are specified.
- initHeight();
- int result = m_iTextHeight;
- if (specMode == MeasureSpec.AT_MOST){
- // Calculate the ideal size of your
- // control within this maximum size.
- // If your control fills the available
- // space return the outer bound.
- result = specSize;
- }else if (specMode == MeasureSpec.EXACTLY){
- // If your control can fit within these bounds return that value.
- result = specSize;
- }
- return result;
- }
- private void initHeight()
- {
- //设置 CY TextView的初始高度为0
- m_iTextHeight=0;
- //大概计算 CY TextView所需高度
- FontMetrics fm = mPaint.getFontMetrics();
- int m_iFontHeight = (int) Math.ceil(fm.descent - fm.top) + (int)LineSpace;
- int line=0;
- int istart=0;
- int w=0;
- for (int i = 0; i < string.length(); i++)
- {
- char ch = string.charAt(i);
- float[] widths = new float[1];
- String srt = String.valueOf(ch);
- mPaint.getTextWidths(srt, widths);
- if (ch == '/n'){
- line++;
- istart = i + 1;
- w = 0;
- }else{
- w += (int) (Math.ceil(widths[0]));
- if (w > m_iTextWidth){
- line++;
- istart = i;
- i--;
- w = 0;
- }else{
- if (i == (string.length() - 1)){
- line++;
- }
- }
- }
- }
- m_iTextHeight=(line)*m_iFontHeight+2;
- }
- private int measureWidth(int measureSpec)
- {
- int specMode = MeasureSpec.getMode(measureSpec);
- int specSize = MeasureSpec.getSize(measureSpec);
- // Default size if no limits are specified.
- int result = 500;
- if (specMode == MeasureSpec.AT_MOST){
- // Calculate the ideal size of your control
- // within this maximum size.
- // If your control fills the available space
- // return the outer bound.
- result = specSize;
- }else if (specMode == MeasureSpec.EXACTLY){
- // If your control can fit within these bounds return that value.
- result = specSize;
- }
- return result;
- }
- public void SetText(String text)(//注:此函数目前只有在UI线程中调用才可以把文本画出来,在其它线程中<p> //无法画文本,找了好久找不到原因,求高手解答)
- {
- string = text;
- // requestLayout();
- // invalidate();
- }
- }</p>
=======================attrs.xml===============================
该文件是自定义的属性,放在工程的res/values下
- <resources>
- <attr name="textwidth" format="integer"/>
- <attr name="typeface">
- <enum name="normal" value="0"/>
- <enum name="sans" value="1"/>
- <enum name="serif" value="2"/>
- <enum name="monospace" value="3"/>
- </attr>
- <declare-styleable name="CYTextView">
- <attr name="textwidth" />
- <attr name="textSize" format="dimension"/>
- <attr name="textColor" format="reference|color"/>
- <attr name="lineSpacingExtra" format="dimension"/>
- <attr name="typeface" />
- </declare-styleable>
- </resources>
=======================main.xml==========================
- <?xml version="1.0" encoding="utf-8"?>
- <ScrollView
- xmlns:Android="http://schemas.android.com/apk/res/android"
- Android:layout_width="320px"
- Android:layout_height="320px"
- Android:background="#ffffffff"
- >
- <LinearLayout
- xmlns:Android="http://schemas.android.com/apk/res/android"
- Android:orientation="vertical"
- Android:layout_width="fill_parent"
- Android:layout_height="fill_parent">
- <com.cy.CYTextView.CYTextView
- xmlns:cy="http://schemas.Android.com/apk/res/ com.cy.CYTextView "
- Android:id="@+id/mv"
- Android:layout_height="wrap_content"
- Android:layout_width="wrap_content"
- cy :textwidth="320"
- cy :textSize="24sp"
- cy :textColor="#aa000000"
- cy :lineSpacingExtra="15sp"
- cy :typeface="serif">
- </com. cy .CYTextView.CYTextView>
- </LinearLayout>
- </ScrollView>
蓝色代码即为自定义View,其中以cy命名空间开头的属性是自定义属性;
=======================Main.java=============================
- public class Main extends Activity {
- CYTextView mCYTextView;
- String text = "Android提供了精巧和有力的组件化模型构建用户的UI部分。主要是基于布局类:View和 ViewGroup。在此基础上,android平台提供了大量的预制的View和xxxViewGroup子类,即布局(layout)和窗口小部件(widget)。可以用它们构建自己的UI。";
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- this.setContentView(R.layout.main);
- mCYTextView = (CYTextView)findViewById(R.id.mv);
- mCYTextView.SetText(text);
- }
- }
- Android textView字体自定义结合HTml
- Android textView字体自定义结合HTml
- Android自定义TextView字体
- Android—自定义TextView字体!
- android TextView设置自定义字体
- android TextView自定义字体样式
- Android TextView 自定义字体设置
- android中TextView与Html结合使用实现字体和颜色的不同,并且换行
- android textview 用html设置字体
- Android中自定义TextView的字体
- android TextView 支持自定义字体和属性
- Android-自定义TextView(彩色字体与霓虹灯字体以及TextView的多项字体效果)
- 自定义TextView字体
- TextView设置自定义字体
- TextView的自定义字体
- Android自定义解析Html的TextView-HtmlView
- Android TextView使用HTML处理字体样式、显示图片等
- Android TextView使用HTML处理字体样式、显示图片等
- Activti跳过中间节点的helloworld实例程序
- Logback 日志异步输出数据库(Oracle)
- 1978 Fibonacci数列 3
- activiti 源码笔记之startProcess
- MSE(Media Source Extensions) 规范
- Android textView字体自定义结合HTml
- package from elpimous
- 【u-boot】device tree访问重要函数--增删改查
- 【学习笔记】JAVA之使用SAX解析XML文件
- 【Java】自从有了BigInteger,我再也不用担心要处理的数据有多大了
- 看懂此文,不再困惑于javascript中的事件绑定、事件冒泡、事件捕获和事件执行顺序
- 坑人的青旅乐山峨眉两日游
- 串行化和CArchive类
- mysql性能调优--总括