Android 开源项目xUtils3使用教程

原文:https://github.com/wyouflf/xUtils3

参考:https://blog.csdn.net/QPC908694753/article/details/70463709

1.先来认识一下xUtils3

1)xUtils3简介

xUtils是目前功能比较完善的一个Android开源框架,最近又发布了xUtil3.0,在增加新功能的同时又提高了框架的性能,下面来看看官方(https://github.com/wyouflf/xUtils3)对xUtils3的介绍:

  • xUtils包含了很多实用的android工具;
  • xUtils支持超大文件(超过2G)上传,更全面的http请求协议支持(11种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响;
  • xUtils 最低兼容Android 4.0 (api level 14);
  • xUtils3变化较多所以建立了新的项目不在旧版(github.com/wyouflf/xUtils)上继续维护, 相对于旧版本: 
    • HTTP实现替换HttpClient为UrlConnection, 自动解析回调泛型, 更安全的断点续传策略;
    • 支持标准的Cookie策略, 区分domain, path;
    • 事件注解去除不常用的功能, 提高性能;
    • 数据库api简化提高性能, 达到和greenDao一致的性能;
    • 图片绑定支持gif(受系统兼容性影响, 部分gif文件只能静态显示), webp; 支持圆角, 圆形, 方形等裁剪, 支持自动旋转。

2)在我们的项目中快速配置xUtils3

xUtils3的配置十分的简单:

2-1)使用Gradle构建时添加一下依赖即可

compile 'org.xutils:xutils:3.3.36'
  •  

如果使用eclipse可以点击下面链接下载aar文件, 然后用zip解压,取出jar包和so文件。

Github下载:https://github.com/wyouflf/xUtils3 
JCenter下载:http://jcenter.bintray.com/org/xutils/xutils/ 
Maven下载1:http://central.maven.org/maven2/org/xutils/xutils/ 
Maven下载2:http://repo1.maven.org/maven2/org/xutils/xutils/

2-2)加入权限

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

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

  3. 2-3)创建Application

 
  1. public class MyApp extends Application {

  2. @Override

  3. public void onCreate() {

  4. super.onCreate();

  5. x.Ext.init(this);

  6. x.Ext.setDebug(false); //输出debug日志,开启会影响性能

  7. }

  8. }

  •  

2-4)在AndroidManifest文件中注册MyApp

 
  1. <application

  2. android:name=".MyApp"

  3. ...

  4. </application>

xUtils3主要包含注解模块、网络模块、图片模块和数据库模块,下面将做一一说明。

2.xUtils3注解模块的使用

xUtils3注解模块在实际开发中的使用如下:

1)Activity的注解的使用如下:

 
  1. @ContentView(R.layout.activity_main)

  2. public class MainActivity extends AppCompatActivity {

  3. @ViewInject(R.id.viewpager)

  4. ViewPager viewPager;

  5. @Override

  6. protected void onCreate(Bundle savedInstanceState) {

  7. super.onCreate(savedInstanceState);

  8. //setContentView(R.layout.activity_main);

  9. x.view().inject(this);

  10. ...

  11. }

  12. }

  •  

2)Fragment的注解的使用如下:

 
  1. @ContentView(R.layout.fragment_http)

  2. public class HttpFragment extends Fragment {

  3. @Nullable

  4. @Override

  5. public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

  6. return x.view().inject(this, inflater, container);

  7. }

  8. @Override

  9. public void onViewCreated(View v, @Nullable Bundle savedInstanceState) {

  10. super.onViewCreated(v, savedInstanceState);

  11. }

  12. }

  13. 3)为按钮设置点击事件

  14. 方法必须私有限定,
  15. 方法参数形式必须和type对应的Listener接口一致.
  16. 注解参数value支持数组: value={id1, id2, id3}
 
  1. /**

  2. * 单击事件

  3. * type默认View.OnClickListener.class,故此处可以简化不写,@Event(R.id.bt_main)

  4. */

  5. @Event(type = View.OnClickListener.class,value = R.id.bt_main)

  6. private void testInjectOnClick(View v){

  7. Snackbar.make(v,"OnClickListener",Snackbar.LENGTH_SHORT).show();

  8. }

  9. /**

  10. * 长按事件

  11. */

  12. @Event(type = View.OnLongClickListener.class,value = R.id.bt_main)

  13. private boolean testOnLongClickListener(View v){

  14. Snackbar.make(v,"testOnLongClickListener",Snackbar.LENGTH_SHORT).show();

  15. return true;

  16. }

强调:使用注解模块一定要注意初始化视图注解框架。

3.xUtils3网络模块的使用

xUtils3网络模块大大方便了在实际开发中网络模块的开发,xUtils3网络模块大致包括GET请求、POST请求、如何使用其他请求方式、上传文件、下载文件、使用缓存等功能,下面将做一一说明:

1)GET请求

 
  1. RequestParams params = new RequestParams(url);

  2. params.addQueryStringParameter("username","abc");

  3. params.addQueryStringParameter("password","123");

  4. x.http().get(params, new Callback.CommonCallback<String>() {

  5. @Override

  6. public void onSuccess(String result) {

  7. //解析result

  8. }

  9. //请求异常后的回调方法

  10. @Override

  11. public void onError(Throwable ex, boolean isOnCallback) {

  12. }

  13. //主动调用取消请求的回调方法

  14. @Override

  15. public void onCancelled(CancelledException cex) {

  16. }

  17. @Override

  18. public void onFinished() {

  19. }

  20. });

  • 下面我们来看下带有缓存的GET请求,POST请求和其他请求方式类似,后面就不再赘述:

带有缓存的GET请求:

 
  1. RequestParams params = new RequestParams(url);

  2. params.addQueryStringParameter("username","abc");

  3. params.addQueryStringParameter("password","123");

  4. // 默认缓存存活时间, 单位:毫秒(如果服务器没有返回有效的max-age或Expires则参考)

  5. params.setCacheMaxAge(1000 * 60);

  6.  
  7. x.http().get(params, new Callback.CacheCallback<String>() {

  8. private boolean hasError = false;

  9. private String result = null;

  10. @Override

  11. public boolean onCache(String result) { //得到缓存数据, 缓存过期后不会进入

  12. this.result = result;

  13. return true; //true: 信任缓存数据, 不再发起网络请求; false不信任缓存数据

  14. }

  15. @Override

  16. public void onSuccess(String result) {

  17. //如果服务返回304或onCache选择了信任缓存,这时result为null

  18. Log.i("JAVA", "开始请求");

  19. if (result != null) {

  20. this.result = result;

  21. }

  22. }

  23. @Override

  24. public void onError(Throwable ex, boolean isOnCallback) {

  25. hasError = true;

  26. Toast.makeText(x.app(), ex.getMessage(), Toast.LENGTH_LONG).show();

  27. if (ex instanceof HttpException) { //网络错误

  28. HttpException httpEx = (HttpException) ex;

  29. int responseCode = httpEx.getCode();

  30. String responseMsg = httpEx.getMessage();

  31. String errorResult = httpEx.getResult();

  32. //...

  33. } else { //其他错误

  34. //...

  35. }

  36. }

  37. @Override

  38. public void onCancelled(CancelledException cex) {

  39. }

  40. @Override

  41. public void onFinished() {

  42. if (!hasError && result != null) {

  43. //成功获取数据

  44. Toast.makeText(x.app(), result, Toast.LENGTH_LONG).show();

  45. }

  46. }

  47. });

  • 上面onCache方法中需要注意的几点: 

a)如果服务端没有返回过期时间,参考params.setCacheMaxAge(maxAge)方法。 
b)客户端会根据服务端返回的header中max-age或expires来确定本地缓存是否给onCache方法。如果服务端没有返回max-age或expires,那么缓存将一直保存,除非这里自己定义了返回false,那么xUtils将请求新数据, 来覆盖它。 
c)如果信任该缓存返回true,将不再请求网络。返回false继续请求网络,但会在请求头中加上ETag,Last-Modified等信息。如果服务端返回304,则表示数据没有更新,不继续加载数据。

2)POST请求

 
  1. RequestParams params = new RequestParams(url);

  2. params.addBodyParameter("username","abc");

  3. params.addParameter("password","123");

  4. params.addHeader("head","android"); //为当前请求添加一个头

  5. x.http().post(params, new Callback.CommonCallback<String>() {

  6. @Override

  7. public void onSuccess(String result) {

  8. //解析result

  9. }

  10. @Override

  11. public void onError(Throwable ex, boolean isOnCallback) {

  12. }

  13. @Override

  14. public void onCancelled(CancelledException cex) {

  15. }

  16. @Override

  17. public void onFinished() {

  18. }

  19. });

  •  

3)其他网络请求方式

 
  1. RequestParams params = new RequestParams(url);

  2. params.addParameter("username","abc");

  3. x.http().request(HttpMethod.PUT, params, new Callback.CommonCallback<String>() {

  4. @Override

  5. public void onSuccess(String result) {

  6. //解析result

  7. }

  8. @Override

  9. public void onError(Throwable ex, boolean isOnCallback) {

  10. }

  11. @Override

  12. public void onCancelled(CancelledException cex) {

  13. }

  14. @Override

  15. public void onFinished() {

  16. }

  17. });

  • 4)上传文件
 
  1. String path="/mnt/sdcard/Download/icon.jpg";

  2. RequestParams params = new RequestParams(url);

  3. params.setMultipart(true);

  4. params.addBodyParameter("file",new File(path));

  5. x.http().post(params, new Callback.CommonCallback<String>() {

  6. @Override

  7. public void onSuccess(String result) {

  8. }

  9. @Override

  10. public void onError(Throwable ex, boolean isOnCallback) {

  11. }

  12. @Override

  13. public void onCancelled(CancelledException cex) {

  14. }

  15. @Override

  16. public void onFinished() {

  17. }

  18. });

  • 5)下载文件

这里以下载apk为例进行说明,apk下载完成后,自动调用系统的安装方法。

 
  1. url = "http://127.0.0.1/server/abc.apk";

  2. RequestParams params = new RequestParams(url);

  3. //自定义保存路径,Environment.getExternalStorageDirectory():SD卡的根目录

  4. params.setSaveFilePath(Environment.getExternalStorageDirectory()+"/myapp/");

  5. //自动为文件命名

  6. params.setAutoRename(true);

  7. x.http().post(params, new Callback.ProgressCallback<File>() {

  8. @Override

  9. public void onSuccess(File result) {

  10. //apk下载完成后,调用系统的安装方法

  11. Intent intent = new Intent(Intent.ACTION_VIEW);

  12. intent.setDataAndType(Uri.fromFile(result), "application/vnd.android.package-archive");

  13. getActivity().startActivity(intent);

  14. }

  15. @Override

  16. public void onError(Throwable ex, boolean isOnCallback) {

  17. }

  18. @Override

  19. public void onCancelled(CancelledException cex) {

  20. }

  21. @Override

  22. public void onFinished() {

  23. }

  24. //网络请求之前回调

  25. @Override

  26. public void onWaiting() {

  27. }

  28. //网络请求开始的时候回调

  29. @Override

  30. public void onStarted() {

  31. }

  32. //下载的时候不断回调的方法

  33. @Override

  34. public void onLoading(long total, long current, boolean isDownloading) {

  35. //当前进度和文件总大小

  36. Log.i("JAVA","current:"+ current +",total:"+total);

  37. }

  38. });

  •  

4.xUtils3图片模块的使用

xUtils3图片模块,重点在于加载图片的4个bind方法,loadDrawable与loadFIle用法和ImageOptions用法,需多加练习。

1)xUtils3 ImageOptions:

 
  1. //通过ImageOptions.Builder().set方法设置图片的属性

  2. ImageOptions imageOptions= new ImageOptions.Builder().setFadeIn(true).build(); //淡入效果

  3. //ImageOptions.Builder()的一些其他属性:

  4. .setCircular(true) //设置图片显示为圆形

  5. .setSquare(true) //设置图片显示为正方形

  6. .setCrop(true).setSize(200,200) //设置大小

  7. .setAnimation(animation) //设置动画

  8. .setFailureDrawable(Drawable failureDrawable) //设置加载失败的动画

  9. .setFailureDrawableId(int failureDrawable) //以资源id设置加载失败的动画

  10. .setLoadingDrawable(Drawable loadingDrawable) //设置加载中的动画

  11. .setLoadingDrawableId(int loadingDrawable) //以资源id设置加载中的动画

  12. .setIgnoreGif(false) //忽略Gif图片

  13. .setParamsBuilder(ParamsBuilder paramsBuilder) //在网络请求中添加一些参数

  14. .setRaduis(int raduis) //设置拐角弧度

  15. .setUseMemCache(true) //设置使用MemCache,默认true

  •  

2)xUtils3 bind方法:

 
  1. // assets file

  2. x.image().bind(imageView, "assets://test.gif", imageOptions);

  3.  
  4. // local file

  5. x.image().bind(imageView, new File("/sdcard/test.gif").toURI().toString(), imageOptions);

  6. x.image().bind(imageView, "/sdcard/test.gif", imageOptions);

  7. x.image().bind(imageView, "file:///sdcard/test.gif", imageOptions);

  8. x.image().bind(imageView, "file:/sdcard/test.gif", imageOptions);

  9.  
  10. x.image().bind(imageView, url, imageOptions, new Callback.CommonCallback<Drawable>() {

  11. @Override

  12. public void onSuccess(Drawable result) {

  13. }

  14. @Override

  15. public void onError(Throwable ex, boolean isOnCallback) {

  16. }

  17. @Override

  18. public void onCancelled(CancelledException cex) {

  19. }

  20. @Override

  21. public void onFinished() {

  22. }

  •  

3)xUtils3 loadDrawable方法:

 
  1. x.image().loadDrawable(url, imageOptions, new Callback.CommonCallback<Drawable>() {

  2. @Override

  3. public void onSuccess(Drawable result) {

  4. imageView.setImageDrawable(result);

  5. }

  6. @Override

  7. public void onError(Throwable ex, boolean isOnCallback) {

  8. }

  9. @Override

  10. public void onCancelled(CancelledException cex) {

  11. }

  12. @Override

  13. public void onFinished() {

  14. }

  15. });

  •  

4)xUtils3 loadFile方法:

当我们通过bind()或者loadDrawable()方法加载了一张图片后,它会保存到本地文件中,那当我需要这张图片时,就可以通过loadFile()方法进行查找。

 
  1. x.image().loadFile(url,imageOptions,new Callback.CacheCallback<File>(){

  2. @Override

  3. public boolean onCache(File result) {

  4. //在这里可以做图片另存为等操作

  5. Log.i("JAVA","file:"+result.getPath()+result.getName());

  6. return true; //相信本地缓存返回true

  7. }

  8. @Override

  9. public void onSuccess(File result) {

  10. }

  11. @Override

  12. public void onError(Throwable ex, boolean isOnCallback) {

  13. }

  14. @Override

  15. public void onCancelled(CancelledException cex) {

  16. }

  17. @Override

  18. public void onFinished() {

  19. }

  20. });

  •  

4.xUtils3数据库模块的使用

1)初始化配置和创建实体类

首先在项目Application中进行初始化配置DaoConfig(与onCreate方法同级目录下):

 
  1. /**

  2. * 初始化DaoConfig配置

  3. */

  4. DbManager.DaoConfig daoConfig = new DbManager.DaoConfig()

  5. //设置数据库名,默认xutils.db

  6. .setDbName("myapp.db")

  7. //设置数据库路径,默认存储在app的私有目录

  8. .setDbDir(new File("/mnt/sdcard/"))

  9. //设置数据库的版本号

  10. .setDbVersion(2)

  11. //设置数据库打开的监听

  12. .setDbOpenListener(new DbManager.DbOpenListener() {

  13. @Override

  14. public void onDbOpened(DbManager db) {

  15. //开启数据库支持多线程操作,提升性能,对写入加速提升巨大

  16. db.getDatabase().enableWriteAheadLogging();

  17. }

  18. })

  19. //设置数据库更新的监听

  20. .setDbUpgradeListener(new DbManager.DbUpgradeListener() {

  21. @Override

  22. public void onUpgrade(DbManager db, int oldVersion, int newVersion) {

  23. }

  24. })

  25. //设置表创建的监听

  26. .setTableCreateListener(new DbManager.TableCreateListener() {

  27. @Override

  28. public void onTableCreated(DbManager db, TableEntity<?> table){

  29. Log.i("JAVA", "onTableCreated:" + table.getName());

  30. }

  31. });

  32. //设置是否允许事务,默认true

  33. //.setAllowTransaction(true)

  34.  
  35. DbManager db = x.getDb(daoConfig);

  •  

然后创建数据库表ChildInfo的实体类:

 
  1. /**

  2. * onCreated = "sql":当第一次创建表需要插入数据时候在此写sql语句

  3. */

  4. @Table(name = "child_info",onCreated = "")

  5. public class ChildInfo {

  6. /**

  7. * name = "id":数据库表中的一个字段

  8. * isId = true:是否是主键

  9. * autoGen = true:是否自动增长

  10. * property = "NOT NULL":添加约束

  11. */

  12. @Column(name = "id",isId = true,autoGen = true,property = "NOT NULL")

  13. private int id;

  14. @Column(name = "c_name")

  15. private String cName;

  16.  
  17. public ChildInfo(String cName) {

  18. this.cName = cName;

  19. }

  20. //默认的构造方法必须写出,如果没有,这张表是创建不成功的

  21. public ChildInfo() {

  22. }

  23. public int getId() {

  24. return id;

  25. }

  26. public void setId(int id) {

  27. this.id = id;

  28. }

  29. public String getcName() {

  30. return cName;

  31. }

  32. public void setcName(String cName) {

  33. this.cName = cName;

  34. }

  35. @Override

  36. public String toString() {

  37. return "ChildInfo{"+"id="+id+",cName='"+cName+'\''+'}';

  38. }

  39. }

  •  

之后就能进行创建和删除数据库的操作了:

2)创建数据库

 
  1. //用集合向child_info表中插入多条数据

  2. ArrayList<ChildInfo> childInfos = new ArrayList<>();

  3. childInfos.add(new ChildInfo("zhangsan"));

  4. childInfos.add(new ChildInfo("lisi"));

  5. childInfos.add(new ChildInfo("wangwu"));

  6. childInfos.add(new ChildInfo("zhaoliu"));

  7. childInfos.add(new ChildInfo("qianqi"));

  8. childInfos.add(new ChildInfo("sunba"));

  9. //db.save()方法不仅可以插入单个对象,还能插入集合

  10. db.save(childInfos);

  •  

3)删除数据库

db.dropDb();
  •  

4)删除表

db.dropTable(ChildInfo.class);
  •  

5)新增表中的数据

 
  1. ChildInfo childInfo = new ChildInfo("zhangsan123");

  2. db.save(childInfo);

6)删除表中的数据

 
  1. //第一种写法:

  2. db.delete(ChildInfo.class); //child_info表中数据将被全部删除

  3. //第二种写法,添加删除条件:

  4. WhereBuilder b = WhereBuilder.b();

  5. b.and("id",">",2); //构造修改的条件

  6. b.and("id","<",4);

  7. db.delete(ChildInfo.class, b);

7)修改表中的数据

 
  1. //第一种写法:

  2. ChildInfo first = db.findFirst(ChildInfo.class);

  3. first.setcName("zhansan2");

  4. db.update(first,"c_name"); //c_name:表中的字段名

  5. //第二种写法:

  6. WhereBuilder b = WhereBuilder.b();

  7. b.and("id","=",first.getId()); //构造修改的条件

  8. KeyValue name = new KeyValue("c_name","zhansan3");

  9. db.update(ChildInfo.class,b,name);

  10. //第三种写法:

  11. first.setcName("zhansan4");

  12. db.saveOrUpdate(first);

8)查询表中的数据

 
  1. //查询数据库表中第一条数据

  2. ChildInfo first = db.findFirst(ChildInfo.class);

  3. Log.i("JAVA",first.toString());

  4. //添加查询条件进行查询

  5. List<ChildInfo> all = db.selector(ChildInfo.class).where("id",">",2).and("id","<",4).findAll();

  6. for(ChildInfo childInfo :all){

  7. Log.i("JAVA",childInfo.toString());

  8. }

5.xUtils3提供的其他一些方法

1)UI异步执行

 
  1. x.task().run(new Runnable() {

  2. @Override

  3. public void run() {

  4. //异步代码

  5. }

  6. });

2)UI同步执行

 
  1. x.task().post(new Runnable() {

  2. @Override

  3. public void run() {

  4. //同步代码

  5. }

  6. });

猜你喜欢

转载自blog.csdn.net/NewActivity/article/details/88396058