小圆点+无限轮播


Layout布局

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >

    <android.support.v4.view.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="250dp"
        ></android.support.v4.view.ViewPager>

    
    <LinearLayout
        android:id="@+id/lin"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@id/viewPager"
        android:gravity="center"
        ></LinearLayout>
    
    
    
    
    
    
    
</RelativeLayout>










MainActivity中


package com.lian.xiaolun;


import java.lang.reflect.ParameterizedType;
import java.util.ArrayList;

import android.os.Bundle;
import android.os.Handler;
import android.app.Activity;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.Menu;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;

public class MainActivity extends Activity {

    String[] tu=new String[]{
            "http://169.254.162.106:8080/haer.jpg",
            "http://169.254.162.106:8080/qianxun.jpg",
            "http://169.254.162.106:8080/mao.jpg",
            "http://169.254.162.106:8080/baqi.jpg",
    };
    private ViewPager pager;
    private LinearLayout lin;
    private ArrayList<ImageView> image_list;
    private ImageView image;
    
    
    Handler handler=new Handler(){
        public void handleMessage(android.os.Message msg) {
            
            if(msg.what==0){
                int currentItem = pager.getCurrentItem();
                currentItem++;
                pager.setCurrentItem(currentItem);
                faSong();
                
            }
        };
        
    };
    
    
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        pager = (ViewPager) findViewById(R.id.viewPager);
        lin = (LinearLayout) findViewById(R.id.lin);
        
        pager.setAdapter(new MyPager(this, tu));
        
        int item=Integer.MAX_VALUE/2-Integer.MAX_VALUE/2%tu.length;
        pager.setCurrentItem(item);
        
        
        //设置圆点
        xiao();
        //滑动设置背景
        pager.setOnPageChangeListener(new OnPageChangeListener() {
            
            @Override
            public void onPageSelected(int position) {
                // TODO Auto-generated method stub
                //重新设置集合图片
                for(int i=0;i<image_list.size();i++){
                    
                    if(position%tu.length==i){
                        
                        image_list.get(i).setImageDrawable(getResources().getDrawable(R.drawable.four));
                    }else{
                        image_list.get(i).setImageDrawable(getResources().getDrawable(R.drawable.normal));
                    }
                    
                    
                }
                
                
            }
            
            @Override
            public void onPageScrolled(int arg0, float arg1, int arg2) {
                // TODO Auto-generated method stub
                
            }
            
            @Override
            public void onPageScrollStateChanged(int arg0) {
                // TODO Auto-generated method stub
                
            }
        });
        
        
        faSong();
        
        
    }
    
    
    //发送消息
    public void faSong(){
        handler.sendEmptyMessageDelayed(0, 2000);
    }
    
    
    

    //小圆点
    public void xiao(){
        image_list = new ArrayList<ImageView>();
        //清空集合
        lin.removeAllViews();
        image_list.clear();
        
        for(int i=0;i<tu.length;i++){
            //创建控件
            image = new ImageView(this);
            if(i==0){
                image.setImageDrawable(getResources().getDrawable(R.drawable.four));
            }else{
                image.setImageDrawable(getResources().getDrawable(R.drawable.normal));
            }
            //设置小点宽高
            LayoutParams param=new LayoutParams(20, 20);
            param.setMargins(5, 0, 5, 0);
            lin.addView(image, param);
            image_list.add(image);
            
        }
        
        
        
        
        
    }
    

}




//适配器中

package com.lian.xiaolun;

import com.lidroid.xutils.BitmapUtils;

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

public class MyPager extends PagerAdapter {

    Context context;
    String[] tu;
    
    
    
    public MyPager(Context context, String[] tu) {
        super();
        this.context = context;
        this.tu = tu;
    }

    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return Integer.MAX_VALUE;
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
        // TODO Auto-generated method stub
        return arg0==arg1;
    }

    
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        // TODO Auto-generated method stub
        
        ImageView image=new ImageView(context);
        
        //BitmapUtils
        BitmapUtils utils=new BitmapUtils(context);
        utils.display(image, tu[position%tu.length]);
        
        
        container.addView(image);
        return image;
    }
    
    
    
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        // TODO Auto-generated method stub
        //super.destroyItem(container, position, object);
        container.removeView((View) object);
        
    }
    
    
    
    
    
    
    
}



//画图

//显示

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle"
    >
    <!-- shape形状  rectangle长方形 -->
    <corners  android:radius="8dp"/>
    <solid android:color="#99ffff"/>  //默认时颜色设置为 #88000000
</shape>




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用 JavaScript 实现轮播图的示例代码,包括小圆点、标题和色块: HTML 代码: ```html <div class="slider"> <ul class="slides"> <li class="slide active"> <img src="slide1.jpg" alt="Slide 1" /> <div class="content"> <h2>Title 1</h2> <p>Description 1</p> </div> </li> <li class="slide"> <img src="slide2.jpg" alt="Slide 2" /> <div class="content"> <h2>Title 2</h2> <p>Description 2</p> </div> </li> <li class="slide"> <img src="slide3.jpg" alt="Slide 3" /> <div class="content"> <h2>Title 3</h2> <p>Description 3</p> </div> </li> </ul> <div class="dots"></div> </div> ``` CSS 代码: ```css .slider { position: relative; } .slides { list-style: none; margin: 0; padding: 0; } .slide { position: absolute; top: 0; left: 0; opacity: 0; transition: opacity 0.5s ease-in-out; } .slide.active { opacity: 1; } .content { position: absolute; bottom: 0; left: 0; width: 100%; padding: 10px; background-color: rgba(0, 0, 0, 0.5); color: #fff; } .content h2 { margin: 0; font-size: 24px; } .content p { margin: 0; font-size: 16px; } .dots { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); display: flex; } .dot { width: 10px; height: 10px; margin: 0 5px; border-radius: 50%; background-color: #ccc; cursor: pointer; } .dot.active { background-color: #fff; } ``` JavaScript 代码: ```js const slides = document.querySelectorAll('.slide'); const dots = document.querySelector('.dots'); let currentSlide = 0; let interval = setInterval(nextSlide, 5000); function nextSlide() { slides[currentSlide].classList.remove('active'); currentSlide = (currentSlide + 1) % slides.length; slides[currentSlide].classList.add('active'); updateDots(); } function updateDots() { dots.innerHTML = ''; for (let i = 0; i < slides.length; i++) { const dot = document.createElement('div'); dot.classList.add('dot'); if (i === currentSlide) { dot.classList.add('active'); } dot.addEventListener('click', () => { slides[currentSlide].classList.remove('active'); currentSlide = i; slides[currentSlide].classList.add('active'); updateDots(); clearInterval(interval); interval = setInterval(nextSlide, 5000); }); dots.appendChild(dot); } } updateDots(); ``` 这段代码实现了一个自动轮播的效果,每 5 秒钟自动切换到下一张图片,并且在图片下方添加了小圆点和标题、色块等内容。当用户点击小圆点时,会切换到对应的图片,并且停止自动轮播,等待 5 秒钟后重新开始自动轮播

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值