Activity基础(4)

来源:互联网 发布:云计算前景分析 编辑:程序博客网 时间:2024/06/17 18:25

样式

一些属性的集合,设置了样式的组件会具备所有样式中的属性
整个app中重复率比较高的组件,一般会把属性提取成style

//在res/values-v14 对应的sdk版本使用不同的样式<style name="MyTextViewStyle" parent="">    <item name="android:layout_width">wrap_content</item>    <item name="android:layout_height">wrap_content</item>    <item name="android:padding">10dp</item>    <item name="android:textColor">@android:color/red</item>    <item name="android:textSize">18sp</item>    <item name="android:textStyle">bold</item></style>//在res/layout/activity_main.xml中<TextView    style="@style/MyTextViewStyle"    android:text="你好" />

访问assets文件夹

assets文件夹 可以存放着H5源码、字体、各种图片、备份数据库

//在assets文件夹中粘贴ttf文件//在layout中创建一个TextView,,不能和style一起使用//在mianActivity中AssetManager manager = getAssets();//可以通过流的方式来加载数据//有一些已经做了处理,直接访问就可以了,如字体访问Typeface ttf = Typeface.createFromAssets(manager,ttf文件路径)tv = (TextView) findViewById(R.id.tv);tv.setTypeface(ttf);

国际化I18N ==”翻译”

//在res/创建文件夹(关键)values-zh-rCN(中文简体)values-zh-rCN(中文繁体)<resources>    <string name="app_name">第五課國際化</string></resources>硬件切换语言,即可生效

XML解析

java解析方式

Dom Dom4j sax
Dom Dom4j : 会将整个xml全部导入到内存,然后去取节点,可以重复遍历
sax :逐行解析,每次只加载一个节点,占用内存小,但是不能回头

pull解析 和sax解析差不多,也是逐行解析,并且是优化的sax,速度更快
pull解析有4个事件 :

1.文档开始
2.文档结束
3.节点开始
4.节点结束

/*1.在assets创建dogs.xml,dog类(属性,setget方法、toString)2.获取资源3.使用pull,必须先创建pull解析器4.开始导入需要解析的xml文件5.当解析器产生第一个事件6.给一个循环,只要事件不为 文档结束,那么久一直往下走*///在xml中xml:<Dogs><Dog id="1"><name>旺财</name><age>1</age><brand>阿拉斯加犬</brand></Dog><Dog id="2"><name>阿黄</name><age>1.5</age><brand>金毛犬</brand></Dog><Dog id="3"><name>二哈</name><age>1</age><brand>哈士奇雪橇犬</brand></Dog></Dogs>//在MainActivity中AssetManager manager = getAssets();InputStream open = manager.open("dogs.xml");// 1.解析一个xml,使用pull,必须先创建pull解析器XmlPullParser newPullParser = Xml.newPullParser();// 2.开始导入需要解析的xml文件newPullParser.setInput(open, "UTF-8");// 3.当解析器产生第一个事件int event = newPullParser.getEventType();// 4. 给一个循环,只要事件不为 文档结束,那么久一直往下走List<Dog> arrayList = null;    Dog dog = null;    while (event != XmlPullParser.END_DOCUMENT) {        switch (event) {            case XmlPullParser.START_DOCUMENT:            arrayList = new ArrayList<Dog>();            break;            case XmlPullParser.START_TAG:            // 判断标签            Log.e("TAG", "::" + newPullParser.getName());            // 分辨判断name的值            // 节点名称            String name = newPullParser.getName();            if (name.equals("Dog")) {                dog = new Dog();                String id = newPullParser.getAttributeValue(0);                dog.setId(Integer.parseInt(id));            } else if (name.equals("name")) {                dog.setName(newPullParser.nextText());            } else if (name.equals("age")) {                dog.setAge(Float.parseFloat(newPullParser.nextText()));            } else if (name.equals("brand")) {                dog.setBrand(newPullParser.nextText());            }            break;            case XmlPullParser.END_TAG:            String endName = newPullParser.getName();            if (endName.equals("Dog")) {                arrayList.add(dog);            }            break;        }        event = newPullParser.next();    }    Log.e("TAG", "::" + arrayList.toString()+"::"+events);
原创粉丝点击