TextView文字排版问题:

本文转载自:http://blog.sina.com.cn/s/blog_821e2bb101011803.html

textview自动换行导致混乱的原因----半角字符与全角字符混乱所致!一般情况下,我们输入的数字、字母以及英文标点都是半角,所以占位无法确定。它们与汉字的占位大大的不同,由于这个原因,导致很多文字的排版都是参差不齐的。对此找到了两种办法可以解决这个问题:
1. 将textview中的字符全角化。即将所有的数字、字母及标点全部转为全角字符,使它们与汉字同占两个字节,这样就可以避免由于占位导致的排版混乱问题了。 半角转为全角的代码如下,只需调用即可。 

  1. /** * 半角转换为全角  
  2.  
  3.  *  
  4.  
  5.  * @param input  
  6.  
  7.  * @return  
  8.  
  9. */  
  10.   
  11. public static String ToDBC(String input) {             
  12.   
  13.          char[] c = input.toCharArray();   
  14.   
  15. for ( int i =  0; i < c.length; i++) {                 
  16.   
  17.          if (c[i] ==  12288) {                    
  18.   
  19.          c[i] = ( char)  32;                     
  20.   
  21.          continue;   
  22.   
  23.           }   
  24.   
  25. if (c[i] >  65280 && c[i] <  65375)   
  26.   
  27.              c[i] = ( char) (c[i] -  65248);   
  28.   
  29.          }   
  30.   
  31. return new String(c);   
  32.   
  33.      }    

2. 去除特殊字符或将所有中文标号替换为英文标号。利用正则表达式将所有特殊字符过滤,或利用replaceAll()将中文标号替换为英文标号。则转化之后,则可解决排版混乱问题。

 
  1. /** * 去除特殊字符或将所有中文标号替换为英文标号  
  2.  
  3.     * @param str  
  4.  
  5.      * @return  
  6.  
  7.      */  
  8.   
  9. public static String stringFilter(String str) {            
  10.   
  11.           str = str.replaceAll( "【",  "[").replaceAll( "】",  "]")   
  12.   
  13.                  .replaceAll( "!",  "!").replaceAll( ":",  ":"); // 替换中文标号   
  14.   
  15.           String regEx =  "[『』]";  // 清除掉特殊字符   
  16.   
  17.           Pattern p = Pattern.compile(regEx);   
  18.   
  19.           Matcher m = p.matcher(str);   
  20.   
  21. return m.replaceAll( "").trim();   
  22.   
  23.      }    

3:TextView在显示中文的时候标点符号不能显示在一行的行首和行尾,如果一个标点符号刚好在一行的行尾,该标点符号就会连同前一个字符跳到下一行显示。

解决方法:在标点符号后加一个空格。

4:一个英文单词不能被显示在两行中( TextView在显示英文时,标点符号是可以放在行尾的,但英文单词也不能分开 )。

5:如果要两行对其的显示效果:有两种方法

方法:

修改Android源代码;将frameworks/base/core/java/android/text下的StaticLayout.java文件中的如下代码:

 
  1. if (c == ' ' || c == '/t' ||   
  2. ((c == '.'  || c == ',' || c == ':' || c == ';') &&   
  3. (j - 1 < here || !Character.isDigit(chs[j - 1 - start])) &&   
  4. (j + 1 >= next || !Character.isDigit(chs[j + 1 - start]))) ||   
  5. ((c == '/' || c == '-') &&   
  6. (j + 1 >= next || !Character.isDigit(chs[j + 1 - start]))) ||   
  7. (c >= FIRST_CJK && isIdeographic(c, true) &&   
  8. j + 1 < next && isIdeographic(chs[j + 1 - start], false))) {   
  9. okwidth = w;   
  10. ok = j + 1;   
  11.   
  12. if (fittop < oktop)   
  13. oktop = fittop;   
  14. if (fitascent < okascent)   
  15. okascent = fitascent;   
  16. if (fitdescent > okdescent)   
  17. okdescent = fitdescent;   
  18. if (fitbottom > okbottom)   
  19. okbottom = fitbottom;   
  20. }  

去掉就可以了。去掉后标点符号可以显示在行首和行尾,英文单词也可以被分开在两行中显示。

posted @ 2013-08-06 19:42  KillerLegend  Views(1174)  Comments(0Edit  收藏  举报