文档章节

android应用自定义字体

李光正
 李光正
发布于 2015/10/15 14:53
字数 1859
阅读 10
收藏 0
Android提供三种字体:“Sans”,“serif“和“monospace”。

  1、在Android XML文件中设置字体
  可以采用android:typeface,例如android:typeface=”monospace”。在这里例子中我们在Activity中对android:text=”Hello, World! 您好”分别进行了四种显示方式,依次为“Sans”,“serif”,“monospace”和系统缺省方式(经试验缺省采用采用sans)。英文字体有差异,貌似中文字体没有差异。XML文件如下:

  <?xml version=“1.0″ encoding=”utf-8″?>
  <TableLayout … … android:stretchColumns = “1”>
  <TableRow>
  <TextView android:text=“sans:”
  android:layout_marginRight=“4px”
  android:textSize=“20sp” />

  <TextView android:text=”Hello, World! 您好”
  android:typeface =“sans” <!– android:typeface用于指定字体–>
  android:textSize=“20sp” />
  </TableRow>

  <TableRow>
  <TextView android:text=“custom:” …. />
  <TextView android:id=“@+id/c12_custom”
  android:text=“Hello, World! 您好”
  android:textSize=“20sp” />
  </TableRow>
  </TableLayout>

  2、使用其他字体

  1)将新字体的TTF文件copy到assets/fonts/目录下面,例如我们将“*.ttf”copy了过去。
  2)我们需要将widget设置为该字体,比较遗憾的是,不能直接在XML文件中进行,需要编写源代码。

  TextView tv = (TextView)findViewById(R.id.c12_custom);
  //从assert中获取有资源,获得app的assert,采用getAserts(),通过给出在assert/下面的相对路径。在实际使用中,字体库可能存在于SD卡上,可以采用createFromFile()来替代createFromAsset。
  Typeface face = Typeface.createFromAsset (getAssets() , “fonts/timesi.ttf” );
  tv.setTypeface (face);

  在模拟器中先后导入华文行楷的字体,大约4M,但是系统无法识别出该字体,没有显示,然后尝试使用英文字体timesi.ttf,正常。因此Android并非和所有的TTF字体都能兼容,尤其在中文特殊字体的支持会存在问题,对于不兼容的字体,Android不出报错,只是无法正常显示。一般而言我们都会使用系统缺省提供的体。
  对于华文行楷字体,我们一开始使用的文件是中文名字,出现报错,后来我们将之改为全小写的英文名称就不会出错,所以在文件命名上需要注意。

  3、一些注意
  使用其他字库,都会消耗程序的空间,这是要非常注意的。而且这些字库有时并不能完全提供你所需要的文字。
  举个例子,省略方式。当文字太多的时候,可以通过省略号省略后面的内容,省略号是使用“…”作为一个字体,可通过android:ellipsize属性进行设置。如果我们需要使用省略功能,需要确保字体具有省略号。此外,为了保证长度的一直,Android会进行填充处理,除了将一个字符更换为省略符合外,后面的字符将更换为一个特殊的Unicode字符,‘ZERO WIDTH NO-BREAK SPACE’ (U+FEFF)。这个字符并占用任何可视的位置,但是保障了string具有同样的长度。不是所有的字体都支持这个特殊的字符,可能会引发一些乱码现象。
  Android是支持国际语言的,但是我们仍需要对custom的字体小心处理。

 

 

 

 

 

android字体大小根据分辨率自动调整

手机设备太多,分辨率也不一样,看到网上大部分的适应字体的方法是定义values320×480或value-hdpi方式去处理。
采用第一种的就惨了,很多设备的分辨率是不一样的,难道要每种都定义吗?
采用第二种的在平板电脑里没有效果。
最后还是代码的方式方便快捷。。。

//遍历设置字体
 
public static void changeViewSize(ViewGroup viewGroup,int screenWidth,int screenHeight) {//传入Activity顶层Layout,屏幕宽,屏幕高
 
                int adjustFontSize = adjustFontSize(screenWidth,screenHeight);
 
                for(int i = 0; i<viewGroup.getChildCount(); i++ ){
 
                        View v = viewGroup.getChildAt(i);
 
                        if(v instanceof ViewGroup){
 
                                changeViewSize((ViewGroup)v,screenWidth,screenHeight);
 
                        }else if(v instanceof Button){//按钮加大这个一定要放在TextView上面,因为Button也继承了TextView
 
                                ( (Button)v ).setTextSize(adjustFontSize+2);
 
                        }else if(v instanceof TextView){
 
                                if(v.getId()== R.id.title_msg){//顶部标题
 
                                        ( (TextView)v ).setTextSize(adjustFontSize+4);
 
                                }else{
 
                                        ( (TextView)v ).setTextSize(adjustFontSize);
 
                                }
 
                        }
 
                }
 
        }
 


//获取字体大小
 
public static int adjustFontSize(int screenWidth, int screenHeight) {
 
                screenWidth=screenWidth>screenHeight?screenWidth:screenHeight;
 
                /**
 
                 * 1. 在视图的 onsizechanged里获取视图宽度,一般情况下默认宽度是320,所以计算一个缩放比率
 
                           rate = (float) w/320   w是实际宽度
 
                   2.然后在设置字体尺寸时 paint.setTextSize((int)(8*rate));   8是在分辨率宽为320 下需要设置的字体大小
 
                          实际字体大小 = 默认字体大小 x  rate
 
                 */
 
                int rate = (int)(5*(float) screenWidth/320); //我自己测试这个倍数比较适合,当然你可以测试后再修改
 
                return rate<15?15:rate; //字体太小也不好看的
 
}
 

最后在Avtivity的oncreate完后调用一下changeViewSize就行了。。。文字大了那么它对应的背景也就跟着大,所以建议控件的背景图片用9宫格类型的图片,看起来舒服。
另外附加,如果你开发的应用想在平板电脑上浏览无碍请在AndroidManifest.xml文件中的manifest节点(DTD建议放在application节点上面)里加入:
<supports-screens
 
        android:anyDensity="true"
 
        android:largeScreens="true"
 
        android:normalScreens="true"
 
        android:smallScreens="true"
        android:resizeable="true"/>
 
 
 
 
 
 
 
 
 
Android 多点缩放字体DEMO

  91熊猫看书采用 多点缩放字体的 模式来 改变字体大小
 \


\

MultiTouchTestActivity

01 package src.youer.text;
02 import java.io.InputStream;
03 import android.app.Activity;
04 import android.os.Bundle;
05 import android.widget.TextView;
06 public class MultiTouchTestActivity extends Activity
07 {
08 @Override
09 public void onCreate(Bundle savedInstanceState)
10 {
11   super.onCreate(savedInstanceState);
12   setContentView(R.layout.main);
13   TextView textView = (TextView) this.findViewById(R.id.text_view);
14   try
15   {
16    textView.setText(readText());
17   }
18   catch (Exception e)
19   {
20    // TODO Auto-generated catch block
21    e.printStackTrace();
22   }
23   float zoomScale = 0.5f;// 缩放比例
24   new ZoomTextView(textView, zoomScale);
25 }
26 /**
27   * 读取txt
28   *
29   * @param str
30   * @return
31   * @throws Exception
32   */
33 public String readText() throws Exception
34 {
35   InputStream is = this.getClass()
36     .getResourceAsStream("/assets/text.txt");
37   int index = is.available();
38   byte data[] = new byte[index];
39   is.read(data);
40   return new String(data, "UTF-8");
41 }
42 }
ZoomTextView
01  
02 package src.youer.text;
03 import android.widget.TextView;
04 public class ZoomTextView extends ZoomView<TextView>
05 {
06 /**最小字体*/
07 public static final float MIN_TEXT_SIZE = 10f;
08  
09 /**最大子图*/
10 public static final float MAX_TEXT_SIZE = 100.0f;
11 /** 缩放比例 */
12 float scale;
13 /** 设置字体大小 */
14 float textSize;
15 public ZoomTextView(TextView view, float scale)
16 {
17   super(view);
18   this.scale = scale;
19   textSize = view.getTextSize();
20 }
21 /**
22   * 放大
23   */
24 protected void zoomOut()
25 {
26   textSize += scale;
27   if (textSize > MAX_TEXT_SIZE)
28   {
29    textSize = MAX_TEXT_SIZE;
30   }
31   view.setTextSize(textSize);
32 }
33 /**
34   * 缩小
35   */
36 protected void zoomIn()
37 {
38   textSize -= scale;
39   if (textSize < MIN_TEXT_SIZE)
40   {
41    textSize = MIN_TEXT_SIZE;
42   }
43   view.setTextSize(textSize);
44 }
45 }
ZoomView
01  
02 package src.youer.text;
03 import android.util.FloatMath;
04 import android.view.MotionEvent;
05 import android.view.View;
06 import android.view.View.OnTouchListener;
07 /**
08 * view缩放
09 *
10 * @author Administrator
11 *
12 * @param <V>
13 */
14 public abstract class ZoomView<V extends View>
15 {
16 protected V view;
17 // -----------------------------------------------
18 private static final int NONE = 0;// 空
19 private static final int DRAG = 1;// 按下第一个点
20 private static final int ZOOM = 2;// 按下第二个点
21 /** 屏幕上点的数量 */
22 private int mode = NONE;
23 /** 记录按下第二个点距第一个点的距离 */
24 float oldDist;
25 public ZoomView(V view)
26 {
27   this.view = view;
28   setTouchListener();
29 }
30 private void setTouchListener()
31 {
32   view.setOnTouchListener(new OnTouchListener()
33   {
34    @Override
35    public boolean onTouch(View v, MotionEvent event)
36    {
37     switch (event.getAction() & MotionEvent.ACTION_MASK)
38     {
39     case MotionEvent.ACTION_DOWN:
40      mode = DRAG;
41      break;
42     case MotionEvent.ACTION_UP:
43     case MotionEvent.ACTION_POINTER_UP:
44      mode = NONE;
45      break;
46     case MotionEvent.ACTION_POINTER_DOWN:
47      oldDist = spacing(event);
48      if (oldDist > 10f)
49      {
50       mode = ZOOM;
51      }
52      break;
53     case MotionEvent.ACTION_MOVE:
54      if (mode == ZOOM)
55      {
56       // 正在移动的点距初始点的距离
57       float newDist = spacing(event);
58       if (newDist > oldDist)
59       {
60        zoomOut();
61       }
62       if (newDist < oldDist)
63       {
64        zoomIn();
65       }
66      }
67      break;
68     }
69     return true;
70    }
71    /**
72     * 求出2个触点间的 距离
73     *
74     * @param event
75     * @return
76     */
77    private float spacing(MotionEvent event)
78    {
79     float x = event.getX(0) - event.getX(1);
80     float y = event.getY(0) - event.getY(1);
81     return FloatMath.sqrt(x * x + y * y);
82    }
83   });
84 }
85 protected abstract void zoomIn();
86 protected abstract void zoomOut();
87
 

本文转载自:http://blog.csdn.net/liguangzhenghi/article/details/7612858

上一篇: MD5算法
李光正
粉丝 5
博文 64
码字总数 0
作品 0
大兴
私信 提问
Android Q 文本新功能

作者: Florina Muntenescu, Android 开发技术推广工程师 文本显示是大部分应用的重要任务之一。为了帮助您打造更好的文本体验,我们在 Android Q 中引入多项新特性,在满足开发者需求的同时,...

Android_开发者
08/05
0
0
自定义控件 –百科专家总结(最后遗留了问题望网友能帮忙解答)

在开发android应用中 经常用到自定义控件 我 就将这段时间 我参与的项目中用到的自定义控件说一下 在百科专家中用到最多的就是 text描边 这是我参考的文章 http://labs.ywlx.net/?p=2739 htt...

汉果James
2012/10/30
123
0
Android通知栏介绍与适配总结(上篇)

此文已由作者黎星授权网易云社区发布。 欢迎访问网易云社区,了解更多网易技术产品运营经验。 由于历史原因,Android在发布之初对通知栏Notification的设计相当简单,而如今面对各式各样的通...

网易云
2018/11/29
0
0
腾讯移动推送(信鸽)首家通过Android 8.0兼容测试

腾讯信鸽率先支持Android 8.0! 腾讯移动推送(信鸽)作为优秀的移动APP推送第三方,首家通过Android 8.0兼容性测试,请开发者放心使用。 腾讯移动推送(信鸽)一直以来为开发者提供着高效、...

腾讯大数据
2017/04/19
242
0
Android Studio 3.0 正式发布,支持 Kotlin 语言

除了 Android 8.1 Oreo 开发者预览版,Google 今日还正式发布了 Android Studio 3.0 ,为其 IDE 引入了一系列新功能。 Android Studio 3.0 专注于加速 Android 应用开发,包含大量更新内容,...

王练
2017/10/26
16.8K
57

没有更多内容

加载失败,请刷新页面

加载更多

只需一步,在Spring Boot中统一Restful API返回值格式与统一处理异常

统一返回值 在前后端分离大行其道的今天,有一个统一的返回值格式不仅能使我们的接口看起来更漂亮,而且还可以使前端可以统一处理很多东西,避免很多问题的产生。 比较通用的返回值格式如下:...

晓月寒丶
昨天
59
0
区块链应用到供应链上的好处和实际案例

区块链可以解决供应链中的很多问题,例如记录以及追踪产品。那么使用区块链应用到各产品供应链上到底有什么好处?猎头悬赏平台解优人才网小编给大家做个简单的分享: 使用区块链的最突出的优...

猎头悬赏平台
昨天
28
0
全世界到底有多少软件开发人员?

埃文斯数据公司(Evans Data Corporation) 2019 最新的统计数据(原文)显示,2018 年全球共有 2300 万软件开发人员,预计到 2019 年底这个数字将达到 2640万,到 2023 年达到 2770万。 而来自...

红薯
昨天
65
0
Go 语言基础—— 通道(channel)

通过通信来共享内存(Java是通过共享内存来通信的) 定义 func service() string {time.Sleep(time.Millisecond * 50)return "Done"}func AsyncService() chan string {retCh := mak......

刘一草
昨天
58
0
Apache Flink 零基础入门(一):基础概念解析

Apache Flink 的定义、架构及原理 Apache Flink 是一个分布式大数据处理引擎,可对有限数据流和无限数据流进行有状态或无状态的计算,能够部署在各种集群环境,对各种规模大小的数据进行快速...

Vincent-Duan
昨天
60
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部