博客
关于我
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 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>