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″?>
android:layout_marginRight=“4px”
android:textSize=“20sp” />
android:typeface =“sans”
android:textSize=“20sp” />
android:text=“Hello, World! 您好”
android:textSize=“20sp” />
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
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节点上面)里加入:
android:anyDensity="true"
android:largeScreens="true"
android:normalScreens="true"
android:smallScreens="true"
android:resizeable="true"/> Android 多点缩放字体DEMO 91熊猫看书采用 多点缩放字体的 模式来 改变字体大小
MultiTouchTestActivity
view source print ? 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 |
09 |
public void onCreate(Bundle savedInstanceState) |
11 | super .onCreate(savedInstanceState); |
12 | setContentView(R.layout.main); |
13 | TextView textView = (TextView) this .findViewById(R.id.text_view); |
16 | textView.setText(readText()); |
23 | float zoomScale = 0 .5f; |
24 | new ZoomTextView(textView, zoomScale); |
33 |
public String readText() throws Exception |
35 | InputStream is = this .getClass() |
36 | .getResourceAsStream( "/assets/text.txt" ); |
37 | int index = is.available(); |
38 | byte data[] = new byte [index]; |
40 | return new String(data, "UTF-8" ); |
ZoomTextView view source print ? 02 | package src.youer.text; |
03 | import android.widget.TextView; |
04 | public class ZoomTextView extends ZoomView |
07 |
public static final float MIN_TEXT_SIZE = 10f; |
10 |
public static final float MAX_TEXT_SIZE = 100 .0f; |
15 |
public ZoomTextView(TextView view, float scale) |
19 | textSize = view.getTextSize(); |
24 |
protected void zoomOut() |
27 | if (textSize > MAX_TEXT_SIZE) |
29 | textSize = MAX_TEXT_SIZE; |
31 | view.setTextSize(textSize); |
36 |
protected void zoomIn() |
39 | if (textSize < MIN_TEXT_SIZE) |
41 | textSize = MIN_TEXT_SIZE; |
43 | view.setTextSize(textSize); |
ZoomView view source print ? 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; |
10 |
* @author Administrator |
14 | public abstract class ZoomViewextends View> |
18 |
private static final int NONE = 0 ; |
19 |
private static final int DRAG = 1 ; |
20 |
private static final int ZOOM = 2 ; |
22 |
private int mode = NONE; |
23 |
/** 记录按下第二个点距第一个点的距离 */ |
25 |
public ZoomView(V view) |
30 |
private void setTouchListener() |
32 | view.setOnTouchListener( new OnTouchListener() |
35 | public boolean onTouch(View v, MotionEvent event) |
37 | switch (event.getAction() & MotionEvent.ACTION_MASK) |
39 | case MotionEvent.ACTION_DOWN: |
42 | case MotionEvent.ACTION_UP: |
43 | case MotionEvent.ACTION_POINTER_UP: |
46 | case MotionEvent.ACTION_POINTER_DOWN: |
47 | oldDist = spacing(event); |
53 | case MotionEvent.ACTION_MOVE: |
57 | float newDist = spacing(event); |
58 | if (newDist > oldDist) |
62 | if (newDist < oldDist) |
77 | private float spacing(MotionEvent event) |
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); |
85 |
protected abstract void zoomIn(); |
86 |
protected abstract void zoomOut(); |
- Android新增AppCompatTextView自适应字体大小和文本宽度
- c#中Noto Sans字体支持韩文的实例教程
- golang如何设置字体
- 试水JetBrains官方新编程字体,真香!
- 9款最佳编程字体推荐
- 破解X眼电影字体动态加密|凹凸玩数据
- 破解大众点评的字体加密,这一篇就够了。
- matplotlib字体设置看这一篇就够了
- 使用sklearn轻松实现数据缩放
随机推荐
-
Android中notifyDataSetInvalidated()和n
-
Android类参考---FragmentManager
-
cocos2d-x之优化图形性能-IOS/Android
-
Android零碎知识点-更新中
-
Android(安卓)Volley 源码解析
-
android中onMeasure初看,深入理解布局之
-
简单的JNI调用
-
Gradle minifyEnabled 使用proguard混淆a
-
Android(安卓)实现定时开关机另类实现--B
-
多级ListView