Android +kotlin Banner 輪播廣告 獲取後臺數據

 



參考網站:
(1) https://www.jianshu.com/p/4f0903469bc8
(2) https://blog.csdn.net/YuEOrange/article/details/78779877#commentBox

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



 <com.youth.banner.Banner
        android:id="@+id/banner"
        android:layout_width="match_parent"
        android:layout_height="300dp"></com.youth.banner.Banner>



//初始化Glic依賴包的類
public class GlidApplication extends ImageLoader {
        //繼承ImageLoader生成displayImage方法
        @Override
        public void displayImage(Context context, Object path, ImageView imageView) {
                //初始化Glide包
                Glide.with(context).load(path).into(imageView);
            }
}

//初始化控件
        banner = (Banner) findViewById(R.id.banner);
        //ok網絡請求
        OkHttpClient okHttpClient = new OkHttpClient();
        Request request = new Request.Builder()
                .url("http://api.tianapi.com/meinv/?key=2a0024d1f7f558e09936f697580f1643&num=5")
                .build();
        Call call = okHttpClient.newCall(request);
        //用OkHttp裏面的Call對象打點調用 異步請求數據的抽象方法
        call.enqueue(new Callback() {
                //建個集合用來存放圖片url的地址
                private List<String> picUrlList;
                //此集合是bean解析過來的集合
                private List<LadyBean.NewslistBean> list;

                @Override
                public void onFailure(Call call, IOException e) {
                        //訪問網絡失敗的方法(自動生成的)
                    }

                //訪問網絡成功的方法(自動生成的)
                @Override
                public void onResponse(Call call, Response response) throws IOException {
                        //把數據流轉換成json字符串
                        String json = response.body().string();
                        Log.e("++++++++","這是訪問到的數據:"+json);
                        //開始用gson解析
                        Gson gson = new Gson();
                        LadyBean ladyBean = gson.fromJson(json, LadyBean.class);
                        //拿到bean類裏的集合
                        list = ladyBean.getNewslist();
                        Log.e("++++++++","這是bean集合裏的數據:"+list);

                        //設全局此集合專門用來存放圖片url地址的
                        picUrlList = new ArrayList<String>();
                        for (int i = 0; i < list.size(); i++) {
                            //循環把圖片地址添加到string泛型的集合裏
                            picUrlList.add(list.get(i).getPicUrl());
                        }
                        Log.e("++++++++","這是專門存放圖片url集合裏的數據:"+picUrlList);

                        //子線程不能更新住UI
                        //所以 【必須】 開啓返回主線程的方法
                        runOnUiThread(new Runnable() {
                            @Override
                            public void run() {
                                //把更新主UI視圖的代碼放這裏面
                                //.setImagees(把圖片地址集合)
                                //.setImageLoader(new你的Glid類)
                                //.start開始裝逼吧
                                banner.setImages(picUrlList).setImageLoader(new GlidApplication()).start();
                            }
                        });

                    }

            });

kotlin 寫法

class MainActivity : AppCompatActivity(), OnBannerListener {


    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        initView()

    }



    private fun initView() {
        var list_path: ArrayList<String>? = null
        var list_title: ArrayList<String>? = null

        //放圖片地址的集合
        list_path = ArrayList<String>()
        //放標題的集合
        list_title = ArrayList<String>()


        list_path.add("http://ww4.sinaimg.cn/large/006uZZy8jw1faic21363tj30ci08ct96.jpg");
        list_path.add("http://imglf5.nosdn0.126.net/img/cEpDYmJybXA5V0dOTmNrVVZjVUt3cG93cDlseFpWOXRTV1NCZFVYMk5LcUpVWGpkdncxTldRPT0.jpg?imageView&thumbnail=500x0&quality=96&stripmeta=0&type=jpg%7Cwatermark&type=2&text=wqkgY2FtZXJhIC8gY2FtY29yZGVyLmxvZnRlci5jb20=&font=bXN5aA==&gravity=southwest&dissolve=30&fontsize=240&dx=8&dy=10&stripmeta=0");
        list_path.add("http://imglf5.nosdn0.126.net/img/b2tFaE5OSVI4QmlndXhMdkhwdjlGQTdOSUlaWEordnR0SkFNZElqTkVtUk9pcUpXZ3VoMXR3PT0.jpg?imageView&thumbnail=500x0&quality=96&stripmeta=0&type=jpg");
        list_path.add("http://ww4.sinaimg.cn/large/006uZZy8jw1faic2e7vsaj30ci08cglz.jpg");

        list_title.add("好好學習");
        list_title.add("天天向上");
        list_title.add("熱愛勞動");
        list_title.add("不搞對象");


        //設置內置樣式,共有六種可以點入方法內逐一體驗使用。
        activity_banner.setBannerStyle(BannerConfig.CIRCLE_INDICATOR_TITLE_INSIDE)
        //設置圖片加載器,圖片加載器在下方
        activity_banner.setImageLoader(MyLoader());
        //設置圖片網址或地址的集合
        activity_banner.setImages(list_path);
        //設置輪播的動畫效果,內含多種特效,可點入方法內查找後內逐一體驗
        activity_banner.setBannerAnimation(Transformer.Default);
        //設置輪播圖的標題集合
        activity_banner.setBannerTitles(list_title);
        //設置輪播間隔時間
        activity_banner.setDelayTime(3000);
        //設置是否爲自動輪播,默認是“是”。
        activity_banner.isAutoPlay(true);
        //設置指示器的位置,小點點,左中右。
        activity_banner.setIndicatorGravity(BannerConfig.CENTER)
            //以上內容都可寫成鏈式佈局,這是輪播圖的監聽。比較重要。方法在下面。
            .setOnBannerListener(this)
            //必須最後調用的方法,啓動輪播圖。
            .start();
    }


    override fun OnBannerClick(position: Int) {
        Log.i("tag", "你點了第"+position+"張輪播圖");
    }
    //自定義的圖片加載器
    private inner class MyLoader : ImageLoader() {
        override fun displayImage(context: Context, path: Any, imageView: ImageView) {
            Glide.with(context).load(path as String).into(imageView)
        }
    }

}

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章