編輯:關於Android編程
首先,我們看一下什麼是serializer,serializer就是串行化,又名序列化。它可並不只是簡單的把對象保存在存儲器上,它可以使我們在流中傳輸對象,使對象變的可以像基本數據一樣傳遞。
XmlSerializer是針對XML進行序列化的類庫,我們先來看一下裡面的常用方法:
基本方法
1.創建一個xml文件的序列化器,返回的是一個Xml的 Serializer 對象。
XmlSerializer = Xml.newSerializer();
2.設置序列化器的輸出路徑和編碼方式
FileOutputStream = new FileOutputStream(new File(Environment.getExternalStorageDirectory(),"文件名.xml")); XmlSerializer.setOutput(FileOutputStream, "編碼");
3.聲明xml文件頭(寫入XML文件中的聲明頭)
serializer.startDocument("xml聲明的編碼", 文檔是否獨立);
4.聲明子節點
Serializer.startTag(nameSpace,String "節點名");
5.聲明節點屬性
Serializer.attribute(命名空間,屬性名,屬性值);
6.聲明節點中的TextNode
Serializer.txt(文本值);
7.設置節點尾標簽
Serializer.endTag(命名空間, "節點名");
8.寫Xml文件尾表示Xml文件結束。
Serializer.endDocument();
9.關閉資源
FileOutputStream.close();
示例

最終效果圖如上
現在粘貼主要代碼:
main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/textView" /> </LinearLayout>
activity的代碼
package cn.com.xmlseriliazer;
import java.io.StringWriter;
import java.util.ArrayList;
import org.xmlpull.v1.XmlPullParserFactory;
import org.xmlpull.v1.XmlSerializer;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
/**
*
* @author chenzheng_java
* @description 測試通過XmlSerilizer生成xml文件
* @since 2011/03/03
*
*/
public class XmlSerializerActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
String result = produceXml();
TextView textView = (TextView)this.findViewById(R.id.textView);
textView.setText(result);
}
/**
*
* @return 生成的xml文件的字符串表示
*/
private String produceXml(){
StringWriter stringWriter = new StringWriter();
ArrayList<Beauty> beautyList = getData();
try {
// 獲取XmlSerializer對象
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
XmlSerializer xmlSerializer = factory.newSerializer();
// 設置輸出流對象
xmlSerializer.setOutput(stringWriter);
/*
* startDocument(String encoding, Boolean standalone)encoding代表編碼方式
* standalone 用來表示該文件是否呼叫其它外部的文件。
* 若值是 ”yes” 表示沒有呼叫外部規則文件,若值是 ”no” 則表示有呼叫外部規則文件。默認值是 “yes”。
*/
xmlSerializer.startDocument("utf-8", true);
xmlSerializer.startTag(null, "beauties");
for(Beauty beauty:beautyList){
/*
* startTag (String namespace, String name)這裡的namespace用於唯一標識xml標簽
*XML 命名空間屬性被放置於某個元素的開始標簽之中,並使用以下的語法:
xmlns:namespace-prefix="namespaceURI"
當一個命名空間被定義在某個元素的開始標簽中時,所有帶有相同前綴的子元素都會與同一個命名空間相關聯。
注釋:用於標示命名空間的地址不會被解析器用於查找信息。其惟一的作用是賦予命名空間一個惟一的名稱。不過,很多公司常常會作為指針來使用命名空間指向某個實存的網頁,這個網頁包含著有關命名空間的信息。
*/
xmlSerializer.startTag(null, "beauty");
xmlSerializer.startTag(null, "name");
xmlSerializer.text(beauty.getName());
xmlSerializer.endTag(null, "name");
xmlSerializer.startTag(null, "age");
xmlSerializer.text(beauty.getAge());
xmlSerializer.endTag(null, "age");
xmlSerializer.endTag(null, "beauty");
}
xmlSerializer.endTag(null, "beauties");
xmlSerializer.endDocument();
} catch (Exception e) {
e.printStackTrace();
}
return stringWriter.toString();
}
/**
*
* @return 包含了眾多美女信息的集合
*/
private ArrayList<Beauty> getData(){
ArrayList<Beauty> beautyList = new ArrayList<Beauty>();
Beauty yangmi = new Beauty("楊冪", "23");
Beauty linzhiling = new Beauty("林志玲", "28");
beautyList.add(yangmi);
beautyList.add(linzhiling);
return beautyList;
}
/**
*
* @author chenzheng_java
* 美人實體類
*/
private class Beauty{
String name;
String age ;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
@Override
public String toString() {
return "Beauty [age=" + age + ", name=" + name + "]";
}
public Beauty(String name, String age) {
this.name = name;
this.age = age;
}
public Beauty(){
}
}
}
其他都為默認。
由代碼我們可以看到,其實使用xmlserializer生成xml也是相當容易的。基本的步驟和解析xml差不多。這裡就不多說話了。詳情請看api。
一個Activity的顯示過程總結(四)
上一篇博客我們講到了ViewRoot中與UI相關的三個重要步驟:performMeasure(測量)、performLayout(布局)和performDraw(繪制),
Android-支付寶支付
前言:緊接著上一篇的微信支付,本篇是集成支付寶支付,相對於微信支付,支付寶的集成就簡單了很多。話不多說,我們來看看怎麼簡單集成支付寶支付。1.看文檔:我們先要去螞蟻金服開
Android實現蒙板效果
本文實例為大家分享了Android實現蒙板效果的相關代碼,供大家參考,具體內容如下1、不保留標題欄蒙板的實現效果:原理:1、彈窗時,設置背景窗體的透明度2、取消彈窗時,恢
Android刮刮卡功能具體實現代碼
今天整理之前的代碼,忽然看到之前自己寫的一個刮刮卡,整理下以便以後使用,同時分享給需要的朋友,如有錯誤,還請多多指正。實現的步驟,其實就是徒手畫三個圖層疊加在一起,最上層