Github下载地址:https://github.com/wyouflf/xUtils

xUtils简单介绍

  • xUtils 包括了非常多有用的Android工具。

  • xUtils 最初源于Afinal框架,进行了大量重构。使得xUtils支持大文件上传。更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,很多其它的事件注解支持且不受混淆影响。
  • xUtils最低兼容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内存;
  • 可配置线程载入线程数量。缓存大小,缓存路径,载入显示动画等...

使用xUtils高速开发框架须要有下面权限:

<uses-permission android:name="android.permission.INTERNET" /> 

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

混淆时注意事项:

  • 加入Android默认混淆配置${sdk.dir}/tools/proguard/proguard-android.txt
  • 不要混淆xUtils中的注解类型,加入混淆配置:-keep class * extends java.lang.annotation.Annotation { *; }
  • 对使用DbUtils模块持久化的实体类不要混淆,或者注解全部表和列名称@Table(name="xxx"),@Id(column="xxx"),@Column(column="xxx"),@Foreign(column="xxx",foreign="xxx")

DbUtils用法

DbUtils db = DbUtils.create(this);
User user = new User(); //这里须要注意的是User对象必须有id属性,或者有通过@ID注解的属性
user.setEmail("wyouflf@qq.com");
user.setName("wyouflf");
db.save(user); // 使用saveBindingId保存实体时会为实体的id赋值 ...
// 查找
Parent entity = db.findById(Parent.class, parent.getId());
List<Parent> list = db.findAll(Parent.class);//通过类型查找 Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","=","test")); // IS NULL
Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","=", null));
// IS NOT NULL
Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","!=", null)); // WHERE id<54 AND (age>20 OR age<30) ORDER BY id LIMIT pageSize OFFSET pageOffset
List<Parent> list = db.findAll(Selector.from(Parent.class)
.where("id" ,"<", 54)
.and(WhereBuilder.b("age", ">", 20).or("age", " < ", 30))
.orderBy("id")
.limit(pageSize)
.offset(pageSize * pageIndex)); // op为"in"时,最后一个參数必须是数组或Iterable的实现类(比如List等)
Parent test = db.findFirst(Selector.from(Parent.class).where("id", "in", new int[]{1, 2, 3}));
// op为"between"时。最后一个參数必须是数组或Iterable的实现类(比如List等)
Parent test = db.findFirst(Selector.from(Parent.class).where("id", "between", new String[]{"1", "5"})); DbModel dbModel = db.findDbModelAll(Selector.from(Parent.class).select("name"));//select("name")仅仅取出name列
List<DbModel> dbModels = db.findDbModelAll(Selector.from(Parent.class).groupBy("name").select("name", "count(name)"));
... List<DbModel> dbModels = db.findDbModelAll(sql); // 自己定义sql查询
db.execNonQuery(sql) // 运行自己定义sql
...

ViewUtils用法

  • 全然注解方式就能够进行UI绑定和事件绑定。
  • 无需findViewById和setClickListener等。

// xUtils的view注解要求必须提供id,以使代码混淆不受影响。
@ViewInject(R.id.textView)
TextView textView; //@ViewInject(vale=R.id.textView, parentId=R.id.parentView)
//TextView textView; @ResInject(id = R.string.label, type = ResType.String)
private String label; // 取消了之前用法名绑定事件的方式,使用id绑定不受混淆影响
// 支持绑定多个id @OnClick({R.id.id1, R.id.id2, R.id.id3})
// or @OnClick(value={R.id.id1, R.id.id2, R.id.id3}, parentId={R.id.pid1, R.id.pid2, R.id.pid3})
// 很多其它事件支持參见ViewCommonEventListener类和包com.lidroid.xutils.view.annotation.event。 @OnClick(R.id.test_button)
public void testButtonClick(View v) { // 方法签名必须和接口中的要求一致
...
}
...
//在Activity中注入:
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ViewUtils.inject(this); //注入view和事件
...
textView.setText("some text...");
...
}
//在Fragment中注入:
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.bitmap_fragment, container, false); // 载入fragment布局
ViewUtils.inject(this, view); //注入view和事件
...
}
//在PreferenceFragment中注入:
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
ViewUtils.inject(this, getPreferenceScreen()); //注入view和事件
...
}
// 其它重载
// inject(View view);
// inject(Activity activity)
// inject(PreferenceActivity preferenceActivity)
// inject(Object handler, View view)
// inject(Object handler, Activity activity)
// inject(Object handler, PreferenceGroup preferenceGroup)
// inject(Object handler, PreferenceActivity preferenceActivity)

HttpUtils用法

普通get方法

HttpUtils http = new HttpUtils();
http.send(HttpRequest.HttpMethod.GET,
"http://www.lidroid.com",
new RequestCallBack<String>(){
@Override
public void onLoading(long total, long current, boolean isUploading) {
testTextView.setText(current + "/" + total);
} @Override
public void onSuccess(ResponseInfo<String> responseInfo) {
textView.setText(responseInfo.result);
} @Override
public void onStart() {
} @Override
public void onFailure(HttpException error, String msg) {
}
});

使用HttpUtils上传文件 或者 提交数据 到server(post方法)

RequestParams params = new RequestParams();
params.addHeader("name", "value");
params.addQueryStringParameter("name", "value"); // 仅仅包括字符串參数时默认使用BodyParamsEntity,
// 类似于UrlEncodedFormEntity("application/x-www-form-urlencoded")。
params.addBodyParameter("name", "value"); // 增加文件參数后默认使用MultipartEntity("multipart/form-data"),
// 如需"multipart/related",xUtils中提供的MultipartEntity支持设置subType为"related"。
// 使用params.setBodyEntity(httpEntity)可设置很多其它类型的HttpEntity(如:
// MultipartEntity,BodyParamsEntity,FileUploadEntity,InputStreamUploadEntity,StringEntity)。 // 比如发送json參数:params.setBodyEntity(new StringEntity(jsonStr,charset));
params.addBodyParameter("file", new File("path"));
... HttpUtils http = new HttpUtils();
http.send(HttpRequest.HttpMethod.POST,
"uploadUrl....",
params,
new RequestCallBack<String>() { @Override
public void onStart() {
testTextView.setText("conn...");
} @Override
public void onLoading(long total, long current, boolean isUploading) {
if (isUploading) {
testTextView.setText("upload: " + current + "/" + total);
} else {
testTextView.setText("reply: " + current + "/" + total);
}
} @Override
public void onSuccess(ResponseInfo<String> responseInfo) {
testTextView.setText("reply: " + responseInfo.result);
} @Override
public void onFailure(HttpException error, String msg) {
testTextView.setText(error.getExceptionCode() + ":" + msg);
}
});

使用HttpUtils下载文件

  • 支持断点续传,随时停止下载任务。開始任务
HttpUtils http = new HttpUtils();
HttpHandler handler = http.download("http://apache.dataguru.cn/httpcomponents/httpclient/source/httpcomponents-client-4.2.5-src.zip",
"/sdcard/httpcomponents-client-4.2.5-src.zip",
true, // 假设目标文件存在,接着未完毕的部分继续下载。 server不支持RANGE时将从新下载。
true, // 假设从请求返回信息中获取到文件名称,下载完毕后自己主动重命名。 new RequestCallBack<File>() { @Override
public void onStart() {
testTextView.setText("conn...");
} @Override
public void onLoading(long total, long current, boolean isUploading) {
testTextView.setText(current + "/" + total);
} @Override
public void onSuccess(ResponseInfo<File> responseInfo) {
testTextView.setText("downloaded:" + responseInfo.result.getPath());
} @Override
public void onFailure(HttpException error, String msg) {
testTextView.setText(msg);
}
}); ...
//调用cancel()方法停止下载
handler.cancel();

BitmapUtils 用法

BitmapUtils bitmapUtils = new BitmapUtils(this);

// 载入网络图片
bitmapUtils.display(testImageView, "http://bbs.lidroid.com/static/image/common/logo.png"); // 载入本地图片(路径以/开头, 绝对路径)
bitmapUtils.display(testImageView, "/sdcard/test.jpg"); // 载入assets中的图片(路径以assets开头)
bitmapUtils.display(testImageView, "assets/img/wallpaper.jpg"); // 使用ListView等容器展示图片时可通过PauseOnScrollListener控制滑动和高速滑动过程中时候暂停载入图片
listView.setOnScrollListener(new PauseOnScrollListener(bitmapUtils, false, true));
listView.setOnScrollListener(new PauseOnScrollListener(bitmapUtils, false, true, customListener));

实例BitmapUtils

  1. public class xUtilsImageLoader {//框架里面设置了缓存和异步操作,不用单独设置线程池和缓存机制(也能够自己定义缓存路径)
  1. private BitmapUtils bitmapUtils;
  1. private Context mContext;
  1. public xUtilsImageLoader(Context context) {
  1. // TODO Auto-generated constructor stub
  1. this.mContext = context;
  1. bitmapUtils = new BitmapUtils(mContext);
  1. bitmapUtils.configDefaultLoadingImage(R.drawable.logo_new);//默认背景图片
  1. bitmapUtils.configDefaultLoadFailedImage(R.drawable.logo_new);//载入失败图片
  1. bitmapUtils.configDefaultBitmapConfig(Bitmap.Config.RGB_565);//设置图片压缩类型
  1. }
  1. /**
  1. *
  1. * @author sunglasses
  1. * @category 图片回调函数
  1. */
  1. public class CustomBitmapLoadCallBack extends
  1. DefaultBitmapLoadCallBack<ImageView> {
  1. @Override
  1. public void onLoading(ImageView container, String uri,
  1. BitmapDisplayConfig config, long total, long current) {
  1. }
  1. @Override
  1. public void onLoadCompleted(ImageView container, String uri,
  1. Bitmap bitmap, BitmapDisplayConfig config, BitmapLoadFrom from) {
  1. // super.onLoadCompleted(container, uri, bitmap, config, from);
  1. fadeInDisplay(container, bitmap);
  1. }
  1. @Override
  1. public void onLoadFailed(ImageView container, String uri,
  1. Drawable drawable) {
  1. // TODO Auto-generated method stub
  1. }
  1. }
  1. private static final ColorDrawable TRANSPARENT_DRAWABLE = new ColorDrawable(
  1. android.R.color.transparent);
  1. /**
  1. * @author sunglasses
  1. * @category 图片载入效果
  1. * @param imageView
  1. * @param bitmap
  1. */
  1. private void fadeInDisplay(ImageView imageView, Bitmap bitmap) {//眼下流行的渐变效果
  1. final TransitionDrawable transitionDrawable = new TransitionDrawable(
  1. new Drawable[] { TRANSPARENT_DRAWABLE,
  1. new BitmapDrawable(imageView.getResources(), bitmap) });
  1. imageView.setImageDrawable(transitionDrawable);
  1. transitionDrawable.startTransition(500);
  1. }
  1. public void display(ImageView container,String url){//外部接口函数
  1. bitmapUtils.display(container, url,new CustomBitmapLoadCallBack());
  1. }
  1. }

实例HttpGet

  1. public class xUtilsGet {//自己主动实现异步处理,自己不用处理
  1. public void getJson(String url,RequestParams params,final IOAuthCallBack iOAuthCallBack){
  1. HttpUtils http = new HttpUtils();
  1. http.configCurrentHttpCacheExpiry(1000 * 10);//设置超时时间
  1. http.send(HttpMethod.GET, url, params, new RequestCallBack<String>() {//接口回调
  1. @Override
  1. public void onFailure(HttpException arg0, String arg1) {
  1. // TODO Auto-generated method stub
  1. }
  1. @Override
  1. public void onSuccess(ResponseInfo<String> info) {
  1. // TODO Auto-generated method stub
  1. iOAuthCallBack.getIOAuthCallBack(info.result);//利用接口回调传输数据
  1. }
  1. });
  1. }
  1. public void getCataJson(int cityId,IOAuthCallBack iOAuthCallBack) {//外部接口函数
  1. String url = "http://xxxxxxxxxx";
  1. RequestParams params = new RequestParams();
  1. params.addQueryStringParameter("currentCityId", cityId+"");
  1. getJson(url,params,iOAuthCallBack);
  1. }
  1. }

实例HttpPost(和HttpGet类似)

  1. public class xUtilsPost {//自己主动实现异步处理
  1. public void doPost(String url, RequestParams params,
  1. final IOAuthCallBack iOAuthCallBack) {
  1. HttpUtils http = new HttpUtils();
  1. http.configCurrentHttpCacheExpiry(1000 * 10);
  1. http.send(HttpMethod.POST, url, params, new RequestCallBack<String>() {
  1. @Override
  1. public void onFailure(HttpException arg0, String arg1) {
  1. // TODO Auto-generated method stub
  1. }
  1. @Override
  1. public void onSuccess(ResponseInfo<String> info) {
  1. // TODO Auto-generated method stub
  1. iOAuthCallBack.getIOAuthCallBack(info.result);
  1. }
  1. });
  1. }
  1. public void doPostLogin(int cityId, IOAuthCallBack iOAuthCallBack) {
  1. String url = "http://xxxxxxxxxxxx";
  1. RequestParams params = new RequestParams();
  1. params.addQueryStringParameter("currentCityId", cityId + "");
  1. params.addBodyParameter("path", "/apps/postCatch");
  1. doPost(url, params, iOAuthCallBack);
  1. }
  1. }

參考链接:http://blog.csdn.net/dj0379/article/details/38356773

最新文章

  1. win8.1硬盘安装ubuntu14.04双系统
  2. Beta阶段发布说明
  3. js继承相关
  4. 2015Summer Training #2
  5. 【转】Xcelsius2008 水晶易表问题 部分汇总
  6. java.lang.UnsupportedClassVersionError: TwoSum : Unsupported major.minor version 52.0
  7. Linux脚本执行过程重定向
  8. JAVA中的Transient
  9. Linq技术四:动态Linq技术 -- Linq.Expressions
  10. 201521123019 《java程序设计》 第14周学习总结
  11. 如何给 mongodb 设置密码
  12. 服务器配置https
  13. 远程git仓库的搭建
  14. redis的使用场景和基本数据类型
  15. 图片按日期分类和查看程序(WPF开发)(附源码)
  16. SQL Server删除log文件
  17. Koa框架教程
  18. MVP 模式简单易懂的介绍方式
  19. 关于JS里面写JAVA代码的问题
  20. linux加载指定目录的so文件

热门文章

  1. Linux系统串口接收数据编
  2. 使用plsql创建package
  3. 洛谷—— P1640 [SCOI2010]连续攻击游戏
  4. JSP简单练习-上传文件
  5. linux中sed的使用方法具体解释(对行数据的加入、删除等)
  6. jquery outerHeight方法 outerWidth方法 获取元素实际宽度高度
  7. TRIZ系列-创新原理-34-抛弃和再生部件原理
  8. 基于One-Class的矩阵分解方法
  9. CodeForces 176B - Word Cut 计数DP
  10. ubuntu16.04通过ipv6进行学术搜索