无限自动轮播

首先添加联网权限和依赖

写一个类继承Application

public class MyApplication extends Application {

@Override
public void onCreate() {
    super.onCreate();

    ImageLoaderConfiguration configuration = new ImageLoaderConfiguration.Builder(this).build();
    ImageLoader.getInstance().init(configuration);
    }
}

Bean类

public class DataBean {

public Data data;

public class Data {
    public List<Adlist> adlist;

}

public class Adlist {

    public String id;
    public String img;

    }
}

联网操作

package com.bwei.utils;

import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;

/**
* 联网操作
*/

public class NetWorkUtils {

private static ByteArrayOutputStream baos;
static String path = "http://www.meirixue.com/api.php?c=index&a=index";

public static String getjson() {
    try {
        URL url = new URL(path);
        HttpURLConnection connection = (HttpURLConnection) url.openConnection();
        connection.setRequestMethod("GET");
        connection.setConnectTimeout(5000);
        int responseCode = connection.getResponseCode();

        baos = new ByteArrayOutputStream();

        if (responseCode == 200) {
            InputStream inputStream = connection.getInputStream();
            int len;
            byte[] arr = new byte[1024];
            while ((len = inputStream.read(arr)) != -1) {
                baos.write(arr, 0, len);
            }
        }
        return baos.toString();
    } catch (Exception e) {

        e.printStackTrace();
    }
    return "";
    }
}

主界面

package com.bwei;

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.widget.ImageView;
import android.widget.LinearLayout;

import com.bwei.adapter.MyAdapter;
import com.bwei.bean.DataBean;
import com.bwei.roolviewpager.R;
import com.bwei.utils.NetWorkUtils;
import com.google.gson.Gson;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

private ViewPager vp;
private LinearLayout ll;
private List<DataBean.Adlist> adlist;
private ImageView iv;
private List<ImageView> ivList;

private Handler handler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
        super.handleMessage(msg);
        int mum = msg.what;

        switch (mum) {
            case 0://判断what是否为0
                String json = (String) msg.obj;
                Log.e("wzq", "handleMessage_json:" + json);
                parseData(json);
                break;

            case 1://无线轮播
                //得到当前viewpager的索引
                int position = vp.getCurrentItem();
                //让当前的的viewpager加1
                position++;
                //给viewPager设置当前的索引
                vp.setCurrentItem(position);
                //延时2秒,发送空消息
                sendMsg();
                break;
        }
    }
};

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    new Thread() {
        @Override
        public void run() {
            super.run();
            String json = NetWorkUtils.getjson();
            Message msg = new Message();
            msg.obj = json;
            msg.what = 0;
            handler.sendMessage(msg);
        }
    }.start();

    vp = (ViewPager) findViewById(R.id.vp);
    ll = (LinearLayout) findViewById(R.id.ll);
}

/**
 * 解析json字符串
 */
private void parseData(String json) {

    Gson gson = new Gson();
    DataBean dataBean = gson.fromJson(json, DataBean.class);
    //得到所有的数据
    adlist = dataBean.data.adlist;
    //把数据传到adapter里面
    MyAdapter adapter = new MyAdapter(adlist, MainActivity.this);
    vp.setAdapter(adapter);

    //初使化点
    initDot();

    //让viewpager的索引默认的指在100000
    vp.setCurrentItem(100000);
    //自动轮播
    sendMsg();
    //viewPager的监听事件
    ViewPagerListener();

}

/**
 * viewpager的滑动监听事件
 */
private void ViewPagerListener() {
    vp.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

        }

        @Override
        public void onPageSelected(int position) {
            for (int x = 0; x < ivList.size(); x++) {

                if (position % adlist.size() == x) {
                    //证明点和图片是对应的,应该点是变红的
                    ivList.get(position % adlist.size()).setImageResource(R.drawable.dot_focuable);
                } else {
                    ivList.get(x).setImageResource(R.drawable.dot_normal);
                }
            }
        }

        @Override
        public void onPageScrollStateChanged(int state) {

        }
    });

}


/**
 * 初使化点的
 */
private void initDot() {
    ivList = new ArrayList<>();
    if (ivList != null) {
        ivList.clear();//清空,每次进来都初始化
    }

    for (int x = 0; x < adlist.size(); x++) {
        iv = new ImageView(MainActivity.this);
        if (x == 0) {
            //第一张,让其圆点进行选中状态
            iv.setImageResource(R.drawable.dot_focuable);//选中
        } else {
            //其它的都不选中
            iv.setImageResource(R.drawable.dot_normal);
        }

        //设置宽高
        LinearLayout.LayoutParams parmes = new LinearLayout.LayoutParams(20, 20);
        //设置两个点之间的距离
        parmes.setMargins(10, 0, 10, 0);
        ll.addView(iv, parmes);
        //把图片放入集合
        ivList.add(iv);
    }
}

/**
 * 实现 自动轮播
 */
private void sendMsg() {
    //延迟发送Handler
    handler.sendEmptyMessageDelayed(1, 2000);
    }
}

主界面

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="200dp">

<android.support.v4.view.ViewPager
    android:id="@+id/vp"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_alignParentTop="true"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true" />

<LinearLayout
    android:id="@+id/ll"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:gravity="center"
    android:orientation="horizontal">

</LinearLayout>

</RelativeLayout>

适配器

package com.bwei.adapter;

import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import com.bwei.bean.DataBean;
import com.nostra13.universalimageloader.core.ImageLoader;

import java.util.List;

public class MyAdapter extends PagerAdapter {

List<DataBean.Adlist> adlist;
Context context;

public MyAdapter(List<DataBean.Adlist> adlist, Context context) {
    this.adlist = adlist;
    this.context = context;
}

//返回最大值
@Override
public int getCount() {
    return Integer.MAX_VALUE;
}

@Override
public boolean isViewFromObject(View view, Object object) {
    return view == object;
}

@Override
public void destroyItem(ViewGroup container, int position, Object object) {
    container.removeView((View) object);
}

@Override
public Object instantiateItem(ViewGroup container, int position) {

    ImageView iv = new ImageView(context);
    //对图片进行缩放
    iv.setScaleType(ImageView.ScaleType.FIT_XY);
    //9    9%4  1   10%4  2
    //url,控件,取余
    ImageLoader.getInstance().displayImage(adlist.get(position % adlist.size()).img, iv);
    container.addView(iv);

    return iv;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值