xUtils簡介
xUtils 包含了很多實用的android工具。
xUtils 源於Afinal框架,對Afinal進行了大量重構,使得xUtils支持大文件上傳,更全面的http請求協議支持,擁有更加靈活的ORM,更多的事件註解支持且不受混淆影響…
xUitls最低兼容android 2.2 (api level 8)
目前xUtils主要有四大模塊:
DbUtils模塊:
android中的orm框架,一行代碼就可以進行增刪改查;
支持事務,默認關閉;
可通過註解自定義表名,列名,外鍵,唯一性約束,NOT NULL約束,CHECK約束等(需要混淆的時候請註解表名和列名);
支持綁定外鍵,保存實體時外鍵關聯實體自動保存或更新;
自動加載外鍵關聯實體,支持延時加載;
支持鏈式表達查詢,更直觀的查詢語義,參考下面的介紹或sample中的例子。
ViewUtils模塊:
android中的ioc框架,完全註解方式就可以進行UI綁定和事件綁定;
新的事件綁定方式,使用混淆工具混淆後仍可正常工作;
目前支持常用的11種事件綁定,參見ViewCommonEventListener類和包com.lidroid.xutils.view.annotation.event。
HttpUtils模塊:
支持同步,異步方式的請求;
支持大文件上傳,上傳大文件不會oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD請求;
下載支持301/302重定向,支持設置是否根據Content-Disposition重命名下載的文件;
返回文本內容的GET請求支持緩存,可設置默認過期時間和針對當前請求的過期時間。
BitmapUtils模塊:
>加載bitmap的時候無需考慮bitmap加載過程中出現的oom和android容器快速滑動時候出現的圖片錯位等現象;
支持加載網絡圖片和本地圖片;
內存管理使用lru算法,更好的管理bitmap內存;
可配置線程加載線程數量,緩存大小,緩存路徑,加載顯示動畫等...
首先這裏介紹用 HttpUtils來進行網絡連接,在知名各控件地址的時候使用ViewUtils
package com.example.administrator.myutiles;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
import com.lidroid.xutils.HttpUtils;
import com.lidroid.xutils.ViewUtils;
import com.lidroid.xutils.exception.HttpException;
import com.lidroid.xutils.http.RequestParams;
import com.lidroid.xutils.http.ResponseInfo;
import com.lidroid.xutils.http.callback.RequestCallBack;
import com.lidroid.xutils.http.client.HttpRequest;
import com.lidroid.xutils.view.annotation.ViewInject;
import com.lidroid.xutils.view.annotation.event.OnClick;
public class MainActivity extends Activity implements View.OnClickListener{
@ViewInject(R.id.button_xutils_get)
private Button mButtonXutilsGet;
@ViewInject(R.id.button_xutils_post)
private Button mButtonXutilsPost;
@ViewInject(R.id.text_xutils)
private TextView mTextXutils;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewUtils.inject(this);
//使用ViewUtils來找到各個控件
}
@OnClick({R.id.button_xutils_get,R.id.button_xutils_post})
//用該註解代替mButtonXutilsGet.setOnClickListener(this);
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.button_xutils_get:
utilsGet();
break;
case R.id.button_xutils_post:
utilsPost();
break;
}
}
private void utilsPost() {
HttpUtils client=new HttpUtils();
//使用HttpUtils 來進行網絡連接和網絡通信
RequestParams params=new RequestParams();
params.addBodyParameter("username","zhangshisan");
client.send(HttpRequest.HttpMethod.POST, "http://192.168.0.30:8080/MyWebTest/MyTestServerlet", params, new RequestCallBack<String>() {
@Override
public void onSuccess(ResponseInfo<String> responseInfo) {
mTextXutils.setText(responseInfo.result);
}
@Override
public void onFailure(HttpException e, String s) {
Toast.makeText(getApplicationContext(), "網絡連接失敗", Toast.LENGTH_LONG).show();
}
});
}
private void utilsGet() {
HttpUtils client = new HttpUtils();
client.send(HttpRequest.HttpMethod.GET, "http://www.360.com", new RequestCallBack<String>() {
@Override
public void onSuccess(ResponseInfo<String> responseInfo) {
mTextXutils.setText(responseInfo.result);
}
@Override
public void onFailure(HttpException e, String s) {
Toast.makeText(getApplicationContext(), "網絡連接失敗", Toast.LENGTH_LONG).show();
}
});
}
}
由以上代碼可以看出,通過使用Xutils使得程序變得更加簡潔和有條理。
下邊在數據庫中來介紹一下DbUtils
首先創建一個關於數據庫表中各列屬性的一個類,這裏用的是User類來表示創建的表user中的數據
@Table(name="user")
//說明表名
public class User {
@Column(column = "id")
//id列
private String id;
private String name;
private String age;
private String sex;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
}
其中每一個屬性都是表中的列名,然後得到每個屬性的set 和get 方法,最重要的是要要說明所要操作的表名和id列。
然後在創建好的數據庫的類中通過查找數據庫中的數據來對DbUtils做一個具體的說明
private void select() {
DbUtils dbUtils=DbUtils.create(this,"firstDatabase");
//這裏要說明操作的數據庫的名字,而不是表名
try {
List <User> users=dbUtils.findAll(Selector.from(User.class));
//將查找的內容放到List集合中
for (User user:users){
Log.d("00000000", "id"+user.getId()+"姓名 :"+user.getName() +" 性別:"+user.getSex()+" 年齡:"+user.getAge());
}
//利用for循環對查找到的數據進行log輸出
} catch (DbException e) {
e.printStackTrace();
}
}