无限轮播

private ViewPager vp;
private LinearLayout ll;
private GridView gv;

List<DataBean> datalist=new ArrayList<>();
List<ImageView> dotlist=new ArrayList<>();

//创建Handler
Handler handler=new Handler(){
    @Override
    public void handleMessage(Message msg) {
        switch(msg.what){
            case 0:
                String json = (String) msg.obj;

                parseData(json);
                break;
            case 1:
                int currentItem = vp.getCurrentItem();
                currentItem++;
                vp.setCurrentItem(currentItem);
                sendMessge();

                break;

        }
    }
};

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    //初始化控件
    initView();
    //线程获取json串
    getjson();

    gv.setAdapter(new Base());

}

//初始化控件的方法
private void initView() {
    //获取事件源
    vp = (ViewPager) findViewById(R.id.vp);
    ll = (LinearLayout) findViewById(R.id.ll);
    gv = (GridView) findViewById(R.id.gv);

}
//线程获取json串,发送hanlder
public void getjson() {
    new Thread(){
        @Override
        public void run() {
            String json = new NewConnectionUrl().getJson("http://v3.wufazhuce.com:8000/api" +
                    "/reading/index/?version=3.5.0&platform=android");
            Message m = new Message();
            m.what=0;
            m.obj=json;
            handler.sendMessage(m);
        }
    }.start();
}

//解析json
private void parseData(String json) {
    Gson gson = new Gson();
    JsonBean jsonBean = gson.fromJson(json, JsonBean.class);
    List<JsonBean.DataBean.EssayBean> essay = jsonBean.getData().getEssay();
    for (JsonBean.DataBean.EssayBean w: essay) {
        List<JsonBean.DataBean.EssayBean.AuthorBean> author = w.getAuthor();
        for (JsonBean.DataBean.EssayBean.AuthorBean r: author) {
            String web_url = r.getWeb_url();
            String desc = r.getDesc();
            DataBean dataBean = new DataBean(desc, web_url);
            datalist.add(dataBean);
            //
        }
    }
    //设置适配器
    VpAdapter vpAdapter = new VpAdapter();
    vp.setAdapter(vpAdapter);
    //设置小点
    initdot();
    //
    vp.setCurrentItem(1000000);
    //
    sendMessge();

    //vp监听
    vp.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

        }
        @Override
        public void onPageSelected(int position) {
            for (int i = 0; i <dotlist.size() ; i++) {
                if(i==position%dotlist.size()){
                    dotlist.get(i).setImageResource(R.drawable.choose);
                }else{
                    dotlist.get(i).setImageResource(R.drawable.notchoose);
                }
            }

        }
        @Override
        public void onPageScrollStateChanged(int state) {

        }
    });

}

//设置小点
private void initdot() {

    if(dotlist!=null){
        dotlist.clear();
    }
    for (int i = 0; i <datalist.size() ; i++) {
        ImageView imageView = new ImageView(MainActivity.this);
        //imageView.setScaleType(ImageView.ScaleType.FIT_XY);
        if(i==0){
            imageView.setImageResource(R.drawable.choose);
        }else{
            imageView.setImageResource(R.drawable.notchoose);
        }
        LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(20, 20);
        layoutParams.setMargins(20,0,20,0);

        ll.addView(imageView,layoutParams);
        dotlist.add(imageView);
        //Log.e("Tag-----------------","设置小点设置小点设置小点设置小点设置小点设置小点设置小点设置小点");

    }

}

//vp.适配器
class VpAdapter extends PagerAdapter{

    @Override
    public int getCount() {
        return Integer.MAX_VALUE;
    }

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

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

        ImageView iv = new ImageView(MainActivity.this);
        //对图片进行缩放
        iv.setScaleType(ImageView.ScaleType.FIT_XY);
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .showImageOnLoading(R.mipmap.ic_launcher) // 设置图片下载期间显示的图片
                .showImageForEmptyUri(R.mipmap.ic_launcher) // 设置图片Uri为空或是错误的时候显示的图片
                .showImageOnFail(R.mipmap.ic_launcher) // 设置图片加载或解码过程中发生错误显示的图片
                .build();
        Log.e("xxx", "instantiateItem: "+datalist.get(position%datalist.size()).getWeb_url());
        ImageLoader.getInstance().displayImage(datalist.get(position%datalist.size()).getWeb_url(),iv,options);
        container.addView(iv);
        return iv;
    }

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

//延迟发送
private void sendMessge() {
    handler.sendEmptyMessageDelayed(1,2000);
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
大学生参加学科竞赛有着诸多好处,不仅有助于个人综合素质的提升,还能为未来职业发展奠定良好基础。以下是一些分析: 首先,学科竞赛是提高专业知识和技能水平的有效途径。通过参与竞赛,学生不仅能够深入学习相关专业知识,还能够接触到最新的科研成果和技术发展趋势。这有助于拓展学生的学科视野,使其对专业领域有更深刻的理解。在竞赛过程中,学生通常需要解决实际问题,这锻炼了他们独立思考和解决问题的能力。 其次,学科竞赛培养了学生的团队合作精神。许多竞赛项目需要团队协作来完成,这促使学生学会有效地与他人合作、协调分工。在团队合作中,学生们能够学到如何有效沟通、共同制定目标和分工合作,这对于日后进入职场具有重要意义。 此外,学科竞赛是提高学生综合能力的一种途径。竞赛项目通常会涉及到理论知识、实际操作和创新思维等多个方面,要求参赛者具备全面的素质。在竞赛过程中,学生不仅需要展现自己的专业知识,还需要具备创新意识和解决问题的能力。这种全面的综合能力培养对于未来从事各类职业都具有积极作用。 此外,学科竞赛可以为学生提供展示自我、树立信心的机会。通过比赛的舞台,学生有机会展现自己在专业领域的优势,得到他人的认可和赞誉。这对于培养学生的自信心和自我价值感非常重要,有助于他们更加积极主动地投入学习和未来的职业生涯。 最后,学科竞赛对于个人职业发展具有积极的助推作用。在竞赛中脱颖而出的学生通常能够引起企业、研究机构等用人单位的关注。获得竞赛奖项不仅可以作为个人履历的亮点,还可以为进入理想的工作岗位提供有力的支持。
以下是使用JavaScript和jQuery实现HTML无限轮播的示例代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>无限轮播</title> <style> #slider { width: 500px; height: 300px; overflow: hidden; position: relative; } #slider img { width: 500px; height: 300px; position: absolute; } #slider .btn { width: 20px; height: 20px; background-color: #fff; border-radius: 50%; position: absolute; bottom: 20px; cursor: pointer; } #slider .btn:hover { background-color: #ccc; } #slider .btn.prev { left: 20px; } #slider .btn.next { right: 20px; } </style> </head> <body> <div id="slider"> <img src="img/1.jpg" alt=""> <img src="img/2.jpg" alt=""> <img src="img/3.jpg" alt=""> <img src="img/4.jpg" alt=""> <img src="img/5.jpg" alt=""> <img src="img/1.jpg" alt=""> <img src="img/2.jpg" alt=""> <img src="img/3.jpg" alt=""> <img src="img/4.jpg" alt=""> <img src="img/5.jpg" alt=""> </div> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> <script> $(function() { var slider = $('#slider'); var imgWidth = slider.find('img').eq(0).width(); var len = slider.find('img').length; var index = 0; var timer; // 自动轮播 function autoPlay() { timer = setInterval(function() { index++; if (index === len) { slider.css('left', 0); index = 1; } slider.animate({left: -index * imgWidth}, 500); }, 2000); } autoPlay(); // 鼠标悬停停止轮播 slider.hover(function() { clearInterval(timer); }, function() { autoPlay(); }); // 左右按钮控制轮播 slider.find('.prev').click(function() { index--; if (index === -1) { slider.css('left', -(len - 1) * imgWidth); index = len - 2; } slider.animate({left: -index * imgWidth}, 500); }); slider.find('.next').click(function() { index++; if (index === len) { slider.css('left', 0); index = 1; } slider.animate({left: -index * imgWidth}, 500); }); }); </script> </body> </html> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值