zoukankan      html  css  js  c++  java
  • 【安卓笔记】切换图片(底部带有小点效果)

    以下我们要实现这种效果:



    我们将採用两种方式实现这样的效果:
    1.使用ViewPager:
    思路:ViewPager提供左右滑动图片操作的支持。下方小点在代码中动态创建,整个布局採用FrameLayout。
    先看布局:
    <FrameLayout 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:background="@android:color/black"
        tools:context=".MainActivity" >
        <android.support.v4.view.ViewPager
            android:id="@+id/viewPager"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            ></android.support.v4.view.ViewPager>
        <RelativeLayout 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            >
            <LinearLayout 
                android:id="@+id/viewGroup"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_marginBottom="30dp"
                android:gravity="center_horizontal"
                android:orientation="horizontal"
                ></LinearLayout>
        </RelativeLayout>
    </FrameLayout>
    再看代码:

    package com.example.splash_viewpager;
    import android.app.Activity;
    import android.content.res.Resources;
    import android.graphics.Bitmap;
    import android.graphics.BitmapFactory;
    import android.os.Bundle;
    import android.support.v4.view.PagerAdapter;
    import android.support.v4.view.ViewPager;
    import android.support.v4.view.ViewPager.OnPageChangeListener;
    import android.view.View;
    import android.view.ViewGroup;
    import android.view.ViewGroup.LayoutParams;
    import android.widget.ImageView;
    import android.widget.LinearLayout;
    public class MainActivity extends Activity implements OnPageChangeListener
    {
        private ViewPager mViewPager = null;
        private LinearLayout mViewGroup = null;
        
        private int[] mImageIds = {R.drawable.bg1,R.drawable.bg2,
                R.drawable.bg3,R.drawable.bg4,
                R.drawable.bg5,R.drawable.bg6,
                R.drawable.bg7};
        
        private ImageView[] mImageViews = null;
        
        private ImageView[] mTips = null;
        
        @Override
        protected void onCreate(Bundle savedInstanceState)
        {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            
            mViewGroup = (LinearLayout) findViewById(R.id.viewGroup);
            mViewPager = (ViewPager) findViewById(R.id.viewPager);
            
            mTips = new ImageView[mImageIds.length];
            //动态创建小点并加到布局中
            for(int i = 0; i < mTips.length; i++)
            {
                ImageView iv = new ImageView(this);
                iv.setLayoutParams(new LayoutParams(10,10));
                mTips[i] = iv;
                
                if(i == 0)
                {
                    iv.setBackgroundResource(R.drawable.page_indicator_focused);
                }else
                {
                    iv.setBackgroundResource(R.drawable.page_indicator_unfocused);
                }
                LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT));
                lp.leftMargin = 5;
                lp.rightMargin = 5;
                mViewGroup.addView(iv,lp);
            }
            mImageViews = new ImageView[mImageIds.length];
            for(int i = 0; i < mImageViews.length; i++)
            {
                ImageView iv = new ImageView(this);
                mImageViews[i] = iv;
                int reqWidth = getWindowManager().getDefaultDisplay().getWidth();
                int reqHeight = getWindowManager().getDefaultDisplay().getHeight();
                iv.setImageBitmap(decodeSampledBitmapFromResource(getResources(), mImageIds[i], reqWidth, reqHeight));
            }
            
            mViewPager.setAdapter(new MyPagerAdapter());
            mViewPager.setOnPageChangeListener(this);
            
        }
        
        class MyPagerAdapter extends PagerAdapter
        {
            @Override
            public int getCount()
            {
                return mImageIds.length;
            }
            @Override
            public boolean isViewFromObject(View arg0, Object arg1)
            {
                return arg0 == arg1;
            }
            @Override
            public Object instantiateItem(ViewGroup container, int position)
            {
                try
                {
                    container.addView(mImageViews[position]);
                } catch (Exception e)
                {
                }
                return mImageViews[position];
            }
            @Override
            public void destroyItem(ViewGroup container, int position, Object object)
            {
            }
        }
        @Override
        public void onPageSelected(int arg0)
        {
            for(int i = 0; i < mTips.length; i++)
            {
                if(arg0 == i)
                {
                    mTips[i].setBackgroundResource(R.drawable.page_indicator_focused);
                }else
                {
                    mTips[i].setBackgroundResource(R.drawable.page_indicator_unfocused);
                }
            }    
        }
        @Override
        public void onPageScrollStateChanged(int arg0)
        {
        }
        @Override
        public void onPageScrolled(int arg0, float arg1, int arg2)
        {
        }
        
        private static Bitmap decodeSampledBitmapFromResource(Resources res,int resId,int reqWidth,int reqHeight)
        {
            BitmapFactory.Options opts = new BitmapFactory.Options();
            opts.inJustDecodeBounds = true;
            BitmapFactory.decodeResource(res, resId);
            int inSampleSize = cacluateInSampledSize(opts, reqWidth, reqHeight);
            opts.inSampleSize = inSampleSize;
            opts.inJustDecodeBounds = false;
            return BitmapFactory.decodeResource(res,resId,opts);
        }
        
        private static int cacluateInSampledSize(BitmapFactory.Options opts,int width,int height)
        {
            if(opts == null)
            {
                return 1;
            }
            int inSampleSize = 1;
            int realWidth = opts.outWidth;
            int realHeight = opts.outHeight;
            
            if(realWidth > width || realHeight > height)
            {
                int heightRatio = realHeight/height;
                int widthRatio = realWidth/width;
                
                inSampleSize = (widthRatio > heightRatio) ? heightRatio : widthRatio;
            }
            return inSampleSize;
        }
    }
    

    2.使用ViewFlipper
    思路:在ViewFlipper中填充多个ImageView,然后使用GestureDetector检測手势,小点仍然是通过动态产生。
    布局:

    <FrameLayout 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:background="@android:color/black"
        tools:context=".MainActivity" >
        
        <ViewFlipper 
            android:id="@+id/vf"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            ></ViewFlipper>
        <RelativeLayout 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            >
            <LinearLayout 
                android:id="@+id/viewGroup"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal"
                android:layout_alignParentBottom="true"
                android:layout_marginBottom="30dp"
                android:gravity="center_horizontal"
                ></LinearLayout>        
        </RelativeLayout>
    </FrameLayout>

    代码:

    package com.example.splash_viewflipper;
    import android.app.Activity;
    import android.content.res.Resources;
    import android.graphics.Bitmap;
    import android.graphics.BitmapFactory;
    import android.os.Bundle;
    import android.view.GestureDetector;
    import android.view.GestureDetector.OnGestureListener;
    import android.view.MotionEvent;
    import android.view.animation.Animation;
    import android.view.animation.AnimationUtils;
    import android.widget.ImageView;
    import android.widget.LinearLayout;
    import android.widget.LinearLayout.LayoutParams;
    import android.widget.Toast;
    import android.widget.ViewFlipper;
    public class MainActivity extends Activity implements OnGestureListener
    {
        private ViewFlipper mViewFlipper = null;
        private LinearLayout mViewGroup = null;
        
        private GestureDetector mGestureDetector = null;
        
        private int[] mImageIds = {
                R.drawable.bg1,R.drawable.bg2,
                R.drawable.bg3,R.drawable.bg4,
                R.drawable.bg5,R.drawable.bg6,
                R.drawable.bg7
        };
        
        private ImageView[] mImageViews = null;
        private ImageView[] mTips = null;
        
        private int currentIndex = 0;
        
        @Override
        protected void onCreate(Bundle savedInstanceState)
        {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            
            mViewFlipper = (ViewFlipper) findViewById(R.id.vf);
            mViewGroup = (LinearLayout) findViewById(R.id.viewGroup);
            
            mGestureDetector = new GestureDetector(this,this);
            
            mImageViews = new ImageView[mImageIds.length];
            for(int i = 0; i < mImageViews.length; i++)
            {
                ImageView iv = new ImageView(this);
                int reqWidth = getWindowManager().getDefaultDisplay().getWidth();
                int reqHeight = getWindowManager().getDefaultDisplay().getHeight();
                iv.setImageBitmap(decodeSampledBitmapFromResource(getResources(),mImageIds[i], reqWidth, reqHeight));
                LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.MATCH_PARENT);
                mViewFlipper.addView(iv,lp);
            }
            
            mTips = new ImageView[mImageIds.length];
            for(int i = 0; i < mTips.length; i++)
            {
                ImageView iv = new ImageView(this);
                iv.setLayoutParams(new LayoutParams(10,10));
                mTips[i] = iv;
                
                if(i == 0)
                {
                    iv.setBackgroundResource(R.drawable.page_indicator_focused);
                }else
                {
                    iv.setBackgroundResource(R.drawable.page_indicator_unfocused);
                }
                LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT));
                lp.leftMargin = 5;
                lp.rightMargin = 5;
                mViewGroup.addView(iv,lp);
            }
        }
        
        @Override
        public boolean onTouchEvent(MotionEvent event)
        {
            return mGestureDetector.onTouchEvent(event);
        }
        
        private static Bitmap decodeSampledBitmapFromResource(Resources res,int resId,int reqWidth,int reqHeight)
        {
            BitmapFactory.Options opts = new BitmapFactory.Options();
            opts.inJustDecodeBounds = true;
            BitmapFactory.decodeResource(res, resId);
            int inSampleSize = cacluateInSampledSize(opts, reqWidth, reqHeight);
            opts.inSampleSize = inSampleSize;
            opts.inJustDecodeBounds = false;
            return BitmapFactory.decodeResource(res,resId,opts);
        }
        
        private static int cacluateInSampledSize(BitmapFactory.Options opts,int width,int height)
        {
            if(opts == null)
            {
                return 1;
            }
            int inSampleSize = 1;
            int realWidth = opts.outWidth;
            int realHeight = opts.outHeight;
            
            if(realWidth > width || realHeight > height)
            {
                int heightRatio = realHeight/height;
                int widthRatio = realWidth/width;
                
                inSampleSize = (widthRatio > heightRatio) ? heightRatio : widthRatio;
            }
            return inSampleSize;
        }
        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
                float velocityY)
        {
            if(e1.getX() - e2.getX() > 120)//显示下一张
            {
                if(currentIndex != mTips.length-1)
                {
                    currentIndex++;
                    setImageBackground(currentIndex);
                    Animation in_right = AnimationUtils.loadAnimation(this,R.anim.in_right_);
                    Animation out_left = AnimationUtils.loadAnimation(this,R.anim.out_left_);
                    mViewFlipper.setInAnimation(in_right);
                    mViewFlipper.setOutAnimation(out_left);
                    mViewFlipper.showNext();
                }else
                {
                    Toast.makeText(this,"已经是最后一张..",0).show();
                }
            }else if(e1.getX() - e2.getX() < -120)//显示上一张
            {
                if(currentIndex != 0)
                {
                    currentIndex--;
                    setImageBackground(currentIndex);
                    Animation in_left = AnimationUtils.loadAnimation(this,R.anim.in_left_);
                    Animation out_right = AnimationUtils.loadAnimation(this,R.anim.out_right_);
                    mViewFlipper.setInAnimation(in_left);
                    mViewFlipper.setOutAnimation(out_right);
                    mViewFlipper.showPrevious();
                }else
                {
                    Toast.makeText(this,"已经是第一张..",0).show();
                }
            }
            return true;
        }
        private void setImageBackground(int selectItems)
        {    
            for(int i = 0; i < mTips.length; i++)
            {    
                if(i == selectItems)
                {    
                    mTips[i].setBackgroundResource(R.drawable.page_indicator_focused);    
                }else
                {    
                    mTips[i].setBackgroundResource(R.drawable.page_indicator_unfocused);    
                }    
            }    
        }
        @Override
        public boolean onDown(MotionEvent e)
        {
            return false;
        }
        @Override
        public void onShowPress(MotionEvent e)
        {
        }
        @Override
        public boolean onSingleTapUp(MotionEvent e)
        {
            return false;
        }
        @Override
        public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
                float distanceY)
        {
            return false;
        }
        @Override
        public void onLongPress(MotionEvent e)
        {
        }
    }





  • 相关阅读:
    揭示同步块索引(下):总结
    关于.NET技术体系的思维导图
    嵌入式Linux中摄像头使用简要整理
    Tslib和Qt 4.8.4与在开发板上的移植
    图像处理经典图片Lena背后的故事
    Linux 下编译安装OpenCV
    Linux 下编译、安装、配置 QT
    Qt Creator的配置和开发初步测试
    OpenCV的第一个小程序:读取图像并显示
    转:智能手机Flash/DRAM选择、配置与价格大全
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/5098269.html
Copyright © 2011-2022 走看看