xUtils简介
xUtils 包含了很多实用的android工具。
xUtils 最初源于Afinal框架,进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响…
xUitls最低兼容android 2.2 (api level 8)
目前xUtils主要有四大模块:
DbUtils模块:
android中的orm框架,一行代码就可以进行增删改查;
支持事务,默认关闭;
可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名);
支持绑定外键,保存实体时外键关联实体自动保存或更新;
自动加载外键关联实体,支持延时加载;
支持链式表达查询,更直观的查询语义,参考下面的介绍或sample中的例子。ViewUtils模块:
android中的ioc框架,完全注解方式就可以进行UI,资源和事件绑定;
新的事件绑定方式,使用混淆工具混淆后仍可正常工作;
目前支持常用的20种事件绑定,参见ViewCommonEventListener类和包com.lidroid.xutils.view.annotation.event。HttpUtils模块
支持同步,异步方式的请求;
支持大文件上传,上传大文件不会oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD,OPTIONS,TRACE,CONNECT请求;
下载支持301/302重定向,支持设置是否根据Content-Disposition重命名下载的文件;
返回文本内容的请求(默认只启用了GET请求)支持缓存,可设置默认过期时间和针对当前请求的过期时间。BitmapUtils模块:
加载bitmap的时候无需考虑bitmap加载过程中出现的oom和android容器快速滑动时候出现的图片错位等现象;
支持加载网络图片和本地图片;
内存管理使用lru算法,更好的管理bitmap内存;
可配置线程加载线程数量,缓存大小,缓存路径,加载显示动画等…
例子
状态图:
代码:
权限:
activity_xutils
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/button_get"
android:text="get连接网络"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button
android:id="@+id/button_post"
android:text="post连接网络"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/textview_content"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</ScrollView>
XutilsActivity
这里用了注解,而没有用以往的findViewById
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import com.example.administrator.networkmode.R;
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;
/**
* Created by Administrator on 2015/9/14.
*/
public class XutilsActivity extends AppCompatActivity implements View.OnClickListener{
@ViewInject(R.id.button_get)
private Button mBtGet;
@ViewInject(R.id.textview_content)
private TextView mTextview;
@ViewInject(R.id.button_post)
private Button mBtPost;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_xutils);
ViewUtils.inject(this);
//使用ViewUtils来找到各个控件
}
@OnClick({R.id.button_get,R.id.button_post})
//用该注解代替mButtonXutilsGet.setOnClickListener(this);
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.button_get:
doGet();
break;
case R.id.button_post:
doPost();
break;
}
}
public void doGet(){
HttpUtils client=new HttpUtils();
client.send(HttpRequest.HttpMethod.GET, "http://www.360.com", new RequestCallBack<String>() {
@Override
public void onSuccess(ResponseInfo<String> responseInfo) {
mTextview.setText(responseInfo.result);
}
@Override
public void onFailure(HttpException e, String s) {
mTextview.setText("网络连接错误");
}
});
}
public void doPost(){
HttpUtils client=new HttpUtils();
RequestParams params=new RequestParams();
params.addBodyParameter("username","zhangsan");
client.send(HttpRequest.HttpMethod.POST, "http://192.168.0.30:8080/MyWebTest/MyTestServerlet", params, new RequestCallBack<String>() {
@Override
public void onSuccess(ResponseInfo<String> responseInfo) {
mTextview.setText(responseInfo.result);
}
@Override
public void onFailure(HttpException e, String s) {
mTextview.setText("网络连接错误");
}
});
}
}
下边在数据库中来介绍一下DbUtils
首先创建一个关于数据库表中各列属性的一个类,这里用的是User类来表示创建的表user中的数据
@Table(name="user") //注解数据表名
public class User {
@Column(column = "id") //或者使用@Column(column="id")
private String id;
private String name; //由于name和password和数据库表中的列名一致,可以不进行注释,否则必须注释
private String password;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
其中每一个属性都是表中的列名,然后得到每个属性的set 和get 方法,最重要的是要要说明所要操作的表名和id列。
然后在创建好的数据库的类中通过查找数据库中的数据来对DbUtils做一个具体的说明
public void DbUtilsSelect(){
DbUtils dbUtils=DbUtils.create(this,"MY_FIRST_DB.db");
//这里要说明操作的数据库的名字,而不是表名
try {
List<User> users =dbUtils.findAll(Selector.from(User.class)); //将查找的内容放到List集合中
for (User user:users){
Log.d("cursor","用户名"+user.getName()+"密码"+user.getPassword());
}
//利用for循环对查找到的数据进行log输出
} catch (DbException e) {
e.printStackTrace();
}
}