XUtils3.0有四大功能
1、注解
2、网络请求
3、数据库
4、图片加载
==========================================================
要使用XUtils必须要进行初始化,通长我们会这样写:
public class MyApp extends Application {
@Override
public void onCreate() {
super.onCreate();
x.Ext.init(this);
x.Ext.setDebug(false);
}
}
写完后不要忘了在清单文件里配置。
一、关于注解,我认为这部分的东西比较散,而且感觉用的地方也不会太多,毕竟ButterKnife、LayoutCreator等工具还是很方便的,遇到复杂的、需要用注解的地方再去查资料就好,没必要死记硬背那些东西。
二、网络请求,这部分分为两块,GET请求与POST请求,首先先说下GET请求方式,代码如下,简单易懂:
public static final String URL_CONTENT = "http://result.eolinker.com/k2BaduF2a6caa275f395919a66ab1dfe4b584cc60685573";
//通长情况下数据的接口是要拼接起来的,所以这里的URL_CONTENT是前半部分,下面params.addQueryStringParameter("uri", url)中,uri和url相当于以键值对的形式存放的,也就是接口的key
RequestParams params = new RequestParams(URL_CONTENT);
//接口里有几个条件就要在这里添加几次
params.addQueryStringParameter("uri", url);
x.http().get(params, new Callback.CommonCallback<String>() {
@Override
public void onSuccess(String result) {
//请求成功的逻辑
}
@Override
public void onError(Throwable ex, boolean isOnCallback) {
//请求失败的逻辑
}
@Override
public void onCancelled(CancelledException cex) {
//主动取消的逻辑
}
@Override
public void onFinished() {
//结束后的逻辑
}
});
POST请求方式:
RequestParams params = new RequestParams(URLUtils.URL_TITLE);
params.addQueryStringParameter("uri", news);
//主要就是下面这两个的区别
params.addHeader("与GET的","区别");
params.addBodyParameter("看这里","看这里");
x.http().post(params, new Callback.CommonCallback<String>() {
@Override
public void onSuccess(String result) {
}
@Override
public void onError(Throwable ex, boolean isOnCallback) {
}
@Override
public void onCancelled(CancelledException cex) {
}
@Override
public void onFinished() {
}
});
三、数据库,这个部分就要用到注解了,XUtils不像SQLiteOpenHelper一样需要写sql语句,需要建表,XUtils的表就是一个JavaBean,就拿今天的代码做个演示好了:
package com.bwie.test.xutils3practisedemo.beans;
import org.xutils.DbManager;
import org.xutils.db.annotation.Column;
import org.xutils.db.annotation.Table;
import org.xutils.ex.DbException;
import java.util.List;
/**
* Created by tianjieyu on 2017/4/11.
*/
//这个注解说明了表的名字叫 ContentTable
@Table(name = "ContentTable")
public class ContentDB {
//字段名id,是否为id,是否自增,还有一些属性在这个代码里没有写
@Column(name = "id",isId = true,autoGen = true)
private int id;
//下面都一样,一个道理
@Column(name = "title")
private String title;
@Column(name = "date")
private String date;
@Column(name = "category")
private String category;
@Column(name = "author_name")
private String author_name;
@Column(name = "url")
private String url;
@Column(name = "pic")
private String thumbnail_pic_s;
public List<ContentDB> getContent(DbManager db) throws DbException {
return db.selector(ContentDB.class).findAll();
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDate() {
return date;
}
public void setDate(String date) {
this.date = date;
}
public String getCategory() {
return category;
}
public void setCategory(String category) {
this.category = category;
}
public String getAuthor_name() {
return author_name;
}
public void setAuthor_name(String author_name) {
this.author_name = author_name;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getThumbnail_pic_s() {
return thumbnail_pic_s;
}
public void setThumbnail_pic_s(String thumbnail_pic_s) {
this.thumbnail_pic_s = thumbnail_pic_s;
}
@Override
public String toString() {
return "ContentDB{" +
"id=" + id +
", title='" + title + '\'' +
", date='" + date + '\'' +
", category='" + category + '\'' +
", author_name='" + author_name + '\'' +
", url='" + url + '\'' +
", thumbnail_pic_s='" + thumbnail_pic_s + '\'' +
'}';
}
}
然后要初始化数据库,在这里我写了一个工具类,直接返回一个DbManager的对象:
public static DbManager dataBaseXUtils(String dbName, int version) {
DbManager.DaoConfig daoConfig = new DbManager.DaoConfig();
//设置数据库名字
daoConfig.setDbName(dbName)
//设置版本号
.setDbVersion(version)
.setDbUpgradeListener(new DbManager.DbUpgradeListener() {
@Override
public void onUpgrade(DbManager db, int oldVersion, int newVersion) {
}
});
DbManager db = x.getDb(daoConfig);
return db;
}
简单的只写了几个属性,够用就好,当然里面还有好多属性。
增:添加数据到数据库
ArrayList<JsonBean.ResultBean.DataBean> data = (ArrayList<JsonBean.ResultBean.DataBean>) jsonBean.getResult().getData();
DbManager dbManager = dataBaseXUtils("News.db", 1);
for (int i=0;i<data.size();i++) {
//相当于table
ContentDB contentDB = new ContentDB();
contentDB.setTitle(data.get(i).getTitle());
contentDB.setAuthor_name(data.get(i).getAuthor_name());
contentDB.setCategory(data.get(i).getCategory());
contentDB.setDate(data.get(i).getDate());
contentDB.setThumbnail_pic_s(data.get(i).getThumbnail_pic_s());
contentDB.setUrl(data.get(i).getUrl());
try {
//保存到数据库
dbManager.save(contentDB);
} catch (DbException e) {
e.printStackTrace();
}
}
查,改,删:如果看不懂以下代码,请返回看JavaBean
ContentDB contentDB = new ContentDB();
try {
List<ContentDB> content = contentDB.getContent(dbManager);
} catch (DbException e) {
e.printStackTrace();
}
content就是查到的所有对象的集合,具体删除和修改就可以在这块进行操作了。
四、图片加载,XUtils3.0的图片加载可以加载成普通矩形图片、四个角为圆角的矩形图片以及圆形的图片。
举个四个叫为圆角的矩形图片的例子,其他两种都只是里面的一些方法的调用而已:
//使用的时候直接调用这个方法就可以了
public static void imageXUtils(ImageView imageView, String iconUrl, boolean isCircluar) {
ImageOptions imageOptions = new ImageOptions.Builder()
//设置裁剪方式 .setImageScaleType(ImageView.ScaleType.CENTER_CROP)
//设置是否缓存
.setUseMemCache(true)
//设置四个角是否为圆角
.setCircular(isCircluar)
//设置是否裁剪
.setCrop(true)
//设置加载时的默认图片
.setLoadingDrawableId(R.mipmap.ic_launcher)
//设置加载失败的默认图片
.setFailureDrawableId(R.mipmap.ic_launcher)
.build();
//绑定图片
x.image().bind(imageView, iconUrl, imageOptions);
}