XUtils3.0 使用

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);
    }

关于XUtils3.0的简单使用就先总结到这里。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值