博客
关于我
Android MVP实现接口Banner轮播图
阅读量:657 次
发布时间:2019-03-15

本文共 3809 字,大约阅读时间需要 12 分钟。

Mainactivity

package com.example.lunbo;import android.content.Context;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;import android.widget.ImageView;import android.widget.Toast;import com.bumptech.glide.Glide;import com.example.lunbo.bean.Result;import com.example.lunbo.bean.User;import com.example.lunbo.core.CallBacks;import com.example.lunbo.presenter.LunPresenter;import com.youth.banner.Banner;import com.youth.banner.loader.ImageLoader;import java.util.ArrayList;import java.util.List;public class MainActivity extends AppCompatActivity implements CallBacks
>{ String url = "http://www.zhaoapi.cn/ad/getAd"; List
string = new ArrayList<>(); List
muser = new ArrayList<>(); private Banner banner; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //获取控件 banner = findViewById(R.id.banner); //创建presenter LunPresenter lunPresenter = new LunPresenter(this); lunPresenter.add(url); } //成功 @Override public void success(List
data) { Toast.makeText(this, ""+data.toString(), Toast.LENGTH_SHORT).show(); muser.addAll(data); //轮播图方法 mBanners(); } //失败 @Override public void fail(Result result) { Toast.makeText(this, ""+result.getMsg(), Toast.LENGTH_SHORT).show(); } //轮播图 private void mBanners() { banner.setImageLoader(new ImageLoader() { @Override public void displayImage(Context context, Object path, ImageView imageView) { // 使用Glide 加载图片 Glide.with(MainActivity.this).load(path).into(imageView); } }); // for循环 加载图片 for (int i = 0; i < muser.size(); i++) { String icon = muser.get(i).getIcon(); string.add(icon); } banner.setImages(string); // 设置 banner.start(); // 开始 }}

布局

Presenter层

package com.example.lunbo.presenter;import android.os.Handler;import android.os.Looper;import android.os.Message;import com.example.lunbo.MainActivity;import com.example.lunbo.bean.Result;import com.example.lunbo.core.CallBacks;import com.example.lunbo.model.LunModel;public class LunPresenter {    CallBacks callBacks;    public LunPresenter(CallBacks callBacks) {        this.callBacks=callBacks;    }    Handler handler = new Handler(Looper.getMainLooper()){        @Override        public void handleMessage(Message msg) {            Result result = (Result) msg.obj;            if (result.getCode()==0){                callBacks.success(result.getData());            }else {                callBacks.fail(result);            }        }    };    public void add(final String url) {        new Thread(new Runnable() {            @Override            public void run() {                Result result = LunModel.lun(url);                Message message = handler.obtainMessage();                message.obj=result;                handler.sendMessage(message);            }        }).start();    }}

Model

package com.example.lunbo.model;import com.example.lunbo.bean.Result;import com.example.lunbo.bean.User;import com.example.lunbo.utils.OkHttp;import com.google.gson.Gson;import com.google.gson.reflect.TypeToken;import java.lang.reflect.Type;import java.util.List;public class LunModel {    public static Result lun(String url){        String s = OkHttp.get(url);        Gson gson = new Gson();        Type type = new TypeToken
>>() {}.getType(); Result result = gson.fromJson(s, type); return result; }}

依赖

compile 'com.youth.banner:banner:1.4.9'

权限

转载地址:http://khfmz.baihongyu.com/

你可能感兴趣的文章
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>