`

解决TextView排版自动换行问题

 
阅读更多
justified实现Textview和Edittext文字左右对齐
https://github.com/programingjd/justified

http://blog.sina.com.cn/s/blog_73615d370100zpt5.html

今天忽然发现android项目中的文字排版参差不齐的情况非常严重,不得不想办法解决一下。经过研究之后,终于找到了textview自动换行导致混乱的原因了----半角字符与全角字符混乱所致!一般情况下,我们输入的数字、字母以及英文标点都是半角,所以占位无法确定。它们与汉字的占位大大的不同,由于这个原因,导致很多文字的排版都是参差不齐的。对此我找到了两种办法可以解决这个问题:

1. 将textview中的字符全角化。即将所有的数字、字母及标点全部转为全角字符,使它们与汉字同占两个字节,这样就可以避免由于占位导致的排版混乱问题了。 半角转为全角的代码如下,只需调用即可。
/**
	 * 半角转换为全角
	 * 
	 * @param input
	 * @return
	 */
	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);
	}

2. 去除特殊字符或将所有中文标号替换为英文标号。利用正则表达式将所有特殊字符过滤,或利用replaceAll()将中文标号替换为英文标号。则转化之后,则可解决排版混乱问题。
/**
	 * 去除特殊字符或将所有中文标号替换为英文标号
	 * 
	 * @param str
	 * @return
	 */
	public static String stringFilter(String str) {
		str = str.replaceAll("【", "[").replaceAll("】", "]")
				.replaceAll("!", "!").replaceAll(":", ":");// 替换中文标号
		String regEx = "[『』]"; // 清除掉特殊字符
		Pattern p = Pattern.compile(regEx);
		Matcher m = p.matcher(str);
		return m.replaceAll("").trim();
	}

解决之前层次不齐的排版截图:



解决之后的整齐排版,如下图:



Android自定义view-文本自动换行
文本自动换行原理:文本超出控件宽度后,自动换到下一行绘制。
实现代码:
protected void onDraw(Canvas canvas) {
        FontMetrics fm = mPaint.getFontMetrics();
        
    float baseline = fm.descent - fm.ascent; 
    float x = 0;
    float y =  baseline;  //由于系统基于字体的底部来绘制文本,所有需要加上字体的高度。
        
    String txt = getResources().getString(com.orgcent.demo.R.string.hello);
        
    //文本自动换行
    String[] texts = autoSplit(txt, mPaint, getWidth() - 5);
        
    System.out.printf("line indexs: %s\n", Arrays.toString(texts));
        
    for(String text : texts) { 
        canvas.drawText(text, x, y, mPaint);  //坐标以控件左上角为原点
        y += baseline + fm.leading; //添加字体行间距
    }
}

/**
 * 自动分割文本
 * @param content 需要分割的文本
 * @param p  画笔,用来根据字体测量文本的宽度
 * @param width 最大的可显示像素(一般为控件的宽度)
 * @return 一个字符串数组,保存每行的文本
 */
private String[] autoSplit(String content, Paint p, float width) {
    int length = content.length();
    float textWidth = p.measureText(content);
    if(textWidth < = width) {
        return new String[]{content};
    }
        
    int start = 0, end = 1, i = 0;
    int lines = (int) Math.ceil(textWidth / width); //计算行数
    String[] lineTexts = new String[lines];
    while(start < length) {
        if(p.measureText(content, start, end) > width) { //文本宽度超出控件宽度时
            lineTexts[i++] = (String) content.subSequence(start, end);
            start = end;
        }
        if(end == length) { //不足一行的文本
            lineTexts[i] = (String) content.subSequence(start, end);
            break;
        }
        end += 1;
    }
    return lineTexts;
}




TextJustify是对安卓TextView控件的格式优化,TextView在显示文字的时候往往在一行的中间部分就跳到了下一行,看起来很杂乱,尤其是在显示英文的时候,TextJustify解决了这个问题。
https://github.com/bluejamesbond/TextJustify-Android
  • 大小: 196.6 KB
  • 大小: 203.8 KB
  • 大小: 14.9 KB
分享到:
评论
4 楼 liufuning 2012-06-18  
奥巴马[E01A][E01A][E01A][E01F][E03B][E154][E03B][E154][E03B][E154]试了一下没反应
3 楼 liufuning 2012-06-18  
不行,我试了都没有反应
2 楼 xinqiqi123 2012-03-17  
大神内否给个图片加载缓存源码,现在项目中的图片都需要缓存处理
1 楼 2006her 2012-03-09  
遇到同样问题的路过,这个bug实在是恶心,感谢楼主分享。

相关推荐

    Android开发TextView排版问题取消自动换行

    本文将详细讲解如何解决TextView的自动换行问题,并结合提供的`CustomTextView.java`源码和`textattr.xml`资源文件来深入理解这一技术。 首先,了解TextView的基本属性。TextView默认会根据其宽度自动进行换行,以...

    Android-TextView换行排版混乱-允许设置SpannableString

    本文将深入探讨如何解决`TextView`自动换行导致的排版问题,并允许我们设置`SpannableString`以实现更多样化的文本效果。 首先,理解`TextView`的换行机制至关重要。`TextView`默认会根据其宽度自动进行文本换行,...

    android textview 文字排版 换行

    它不仅可以显示单行文本,还能处理复杂的文字排版,包括自动换行。本文将深入探讨`TextView`在处理文字排版和换行方面的知识,以及如何优化其性能。 ### 一、TextView的基础用法 1. **XML布局中声明TextView** 在...

    Android TextView 换行不对齐的问题

    然而,有时开发者会遇到一个棘手的问题,即`TextView`中的换行文字可能不会对齐,尤其是在多行显示时。这个问题通常表现为每一行的起始位置不一致,影响了整体布局的美观度。本文将深入探讨这个问题及其解决方案。 ...

    自定义TextView解决文字排版混乱方法

    android开发中的textview可以自动换行,但是对于显示纯英文文字来说很好用,如果夹杂了中文字符后,全角字符和半角字符混在一块儿,就会出现文字排版参差不齐,超级难看,这就需要重写textview来实现我们需要的显示...

    解决 TextView 中文、英文、数字、符号 排版问题

    然而,当TextView中包含中文、英文、数字和符号时,可能会出现排版问题,如字符间距离不均、换行混乱等。为了解决这些问题,开发者需要对TextView的属性进行调整或使用特定的解决方案。 首先,我们要理解Android...

    textView根据长度自动换行.zip

    "textView根据长度自动换行.zip"这个压缩包很可能包含了关于如何在TextView中实现文本自动换行的源码示例或者教程。在Android中,TextView的换行功能是默认开启的,但有时开发者可能需要对这个功能进行自定义,以...

    安卓Andriod源码——textView根据长度自动换行.zip

    本资源"安卓Andriod源码——textView根据长度自动换行.zip"可能包含了一个示例项目,演示了如何在TextView中实现这一功能。 首先,我们了解TextView的基本属性。在XML布局文件中,TextView可以通过`android:single...

    TextView自动换行源代码

    本类实现了文字的竖直排版显示(中国古时的行文形式),虽然仍有许多特效及功能仍未实现,但基本的使用已经能满足。版权:尽管放心用吧,可以自行随意改进转载和使用,转载时请保留这段文字即可另特别感谢 老僧xp ...

    TextView图文排版不规范问题

    这个代码我是我在别的地方下载来的 主要是重写TextView,如果你想用在EditView直接把TextView换成EditView就行。...你要你是想解决TextView排版问题的,这个一定可以用。这个CSDN为什么不能上传图片的呢

    Android AutoWrapTextView中英文排版问题的解决方法

    AutoWrapTextView是为了解决Android系统中TextView在显示中英文混合文本时可能出现的排版问题而设计的一个自定义视图组件。默认的TextView在处理中英文混排时,可能会因为不同字符间的间距不一致导致排版混乱。为了...

    浅谈Android textview文字对齐换行的问题

    经过研究之后,终于找到了textview自动换行导致混乱的原因了—-半角字符与全角字符混乱所致!一般情况下,我们输入的数字、字母以及英文标点都是半角,所以占位无法确定。 它们与汉字的占位大大的不同,由于这个原因...

    安卓textView相关-TextView中文本的处理.rar

    3. **文本换行与最大行数**:默认情况下,TextView会自动换行以适应屏幕宽度。`setMaxLines()`方法可以限制显示的最大行数,防止文本溢出。 4. **单行文本居中**:若希望单行文本居中,可使用`setGravity(Gravity....

    TextViewDemo.zip

    总之,`TextViewDemo.zip`中的示例涵盖了Android开发中处理TextView排版的多个关键点,包括自动换行、文本截断、动态宽度计算以及针对不同屏幕的适配策略。通过学习这个示例,开发者可以更好地理解和掌握TextView的...

    安卓Android源码——textView1.rar

    7. **滚动与换行**:如果文本过长,TextView会自动处理换行和滚动。源码中会包含处理这些问题的相关算法。 8. **性能优化**:对于大量文本的显示,理解TextView的缓存机制,如HardwareLayer的使用,可以提升应用的...

    Android-TextView-not-change-line-in-advance:不会因为有标点符号等问题随便换行的textview

    在Android开发中,TextView是用于显示文本的基本组件,它能够根据文本内容自动换行以适应屏幕宽度。然而,有时候开发者可能会遇到这样的问题:TextView在遇到标点符号或其他特定字符时,可能并不按照预期的方式换行...

    自适应内容的TextView

    例如,`android:maxLines="1"`将限制TextView只显示一行文本,如果内容超过该行,它将自动换行。结合`android:ellipsize`属性,可以实现超出部分用省略号表示。 3. **自定义View扩展TextView**:当系统默认的...

    安卓TextView自适应

    2. **自动换行处理**:通过智能识别单词边界,避免单词在行尾被截断,而是将其完整地移到下一行显示,从而保持文本的可读性。 3. **多语言支持**:考虑到应用可能需要支持多种语言,优化后的TextView可能包含了对...

    Android中多行文本末尾添加图片排版问题的解决方法

    Android中多行文本末尾添加图片排版问题的解决方法需要理解TextView的绘制机制和SpannableString的使用,使用ImageSpan和SpannableString可以将图片放置在最后一行,并使用计算每一行能够容纳的字符个数来解决换行...

    Android软件开发之TextView详解源码

    接着,TextView支持多种格式化特性,如文本样式(粗体、斜体)、链接、对齐方式、换行处理等。例如,Spannable和SpannableString类允许我们对文本的不同部分应用不同的样式或行为。在源码中,TextView会根据这些标记...

Global site tag (gtag.js) - Google Analytics