Android Banner 简单实现

参考 http://www.jianshu.com/p/f8bf9e8b0a39

ViewPageAdapter

public class ViewPagerAdapter extends PagerAdapter {

    private List<Integer> data;

    public ViewPagerAdapter(List<Integer> data) {
        this.data = data;
    }

    @Override
    public int getCount() {
        return data.size();
    }

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

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        ImageView imageView = new ImageView(container.getContext());
        imageView.setScaleType(ImageView.ScaleType.CENTER);
        imageView.setBackgroundResource(data.get(position));
        container.addView(imageView);
        return imageView;
//        return super.instantiateItem(container, position);
    }

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

布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.example.alex.viewpagerdemo.MainActivity">

    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

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

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="40dp"
            android:layout_gravity="bottom"
            android:background="#9977">

            <TextView
                android:id="@+id/banner_title"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:text="怎么了"
                android:gravity="center_vertical"
                android:textColor="@android:color/white"
                android:paddingLeft="20dp"/>

            <TextView
                android:id="@+id/banner_indicator"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:text="1/4"
                android:gravity="center_vertical"
                android:textColor="@android:color/white"
                android:layout_alignParentRight="true"
                android:layout_marginRight="20dp"/>

        </RelativeLayout>

    </FrameLayout>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="SortLayout"
        android:textAllCaps="false"
        android:onClick="sort"/>

</LinearLayout>

MainActivity

public class MainActivity extends AppCompatActivity {

    ViewPager viewPager;
    ViewPagerAdapter adapter;
    List<Integer> data;
    List<String> titleData;
    int currentPage = 0;
    boolean viewPagerScrollStatus = false; //标志位,当在手动翻页时,自动翻页暂停

    TextView title, indicator;

    Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            if (!viewPagerScrollStatus) {
                viewPager.setCurrentItem(++currentPage);
            }
            handler.sendEmptyMessageDelayed(1, 1000);
        }
    };

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

        viewPager = (ViewPager) findViewById(R.id.viewpager);
        title = (TextView) findViewById(R.id.banner_title);
        indicator = (TextView) findViewById(R.id.banner_indicator);
        data = new ArrayList<>(); titleData = new ArrayList<>();
        data.add(R.mipmap.t);     titleData.add("4.哦");
        data.add(R.mipmap.a);     titleData.add("1.怎么了");
        data.add(R.mipmap.b);     titleData.add("2.没事");
        data.add(R.mipmap.c);     titleData.add("3.那好吧");
        data.add(R.mipmap.t);     titleData.add("4.哦");
        data.add(R.mipmap.a);     titleData.add("1.怎么了");
        adapter = new ViewPagerAdapter(data);
        viewPager.setAdapter(adapter);

        viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                //头尾衔接,无限循环
                if (position == data.size() - 1) {
                    currentPage = 1;
                } else if (position == 0) {
                    currentPage = data.size() - 2;
                } else {
                    currentPage = position;
                }
            }

            @Override
            public void onPageScrollStateChanged(int state) {
                if (state == ViewPager.SCROLL_STATE_IDLE) {
                    viewPagerScrollStatus = false;
                    viewPager.setCurrentItem(currentPage, false);
                    title.setText(titleData.get(currentPage));
                    indicator.setText(currentPage + "/" + (titleData.size() - 2));
                } else {
                    viewPagerScrollStatus = true;
                }
            }
        });
        handler.sendEmptyMessageDelayed(1, 1000);

        viewPager.setPageTransformer(true, new ViewPager.PageTransformer() {
            @Override
            public void transformPage(View page, float position) {

                int width = page.getWidth();
                //我们给不同状态的页面设置不同的效果
                //通过position的值来分辨页面所处于的状态
                if (position < -1) {//滑出的页面
                    page.setScrollX((int) (width * 0.75 * -1));
                } else if (position <= 1) {//[-1,1]
                    if (position < 0) {//[-1,0]
                        page.setScrollX((int) (width * 0.75 * position));
                    } else {//[0,1]
                        page.setScrollX((int) (width * 0.75 * position));
                    }
                } else {//即将滑入的页面
                    page.setScrollX((int) (width * 0.75));
                }
            }
        });
    }

    public void sort(View v) {
        startActivity(new Intent(this, SortLayoutActivity.class));
    }
}

效果
这里写图片描述

### 回答1: 在Android实现阴影效果可以通过几种方式实现,以下是几种常用的方法: 1. 使用阴影的背景资源:可以在XML文件中创建一个带有阴影效果的背景资源,然后将其应用于Banner组件或其父布局,以达到阴影的效果。可以利用GradientDrawable和LayerDrawable等drawable类创建一个阴影资源,然后通过android:background属性将其应用于Banner组件。 2. 使用CardView:CardView是一种常用的用于创建阴影效果的布局容器,可以将Banner组件放置在CardView容器中,然后通过设置CardView的elevation属性和cardElevation属性来实现阴影效果。可以在XML布局文件中使用CardView包裹Banner组件,并设置相应的阴影属性,然后在Java代码中对Banner进行相关的设置。 3. 使用自定义阴影效果:可以通过绘制阴影效果的自定义Drawable实现阴影效果。可以自定义阴影效果的形状、颜色、大小等属性,并将其应用于Banner组件或其父布局。可以创建一个类继承自Drawable类,并在类的draw方法中实现具体的绘制阴影的逻辑。 总结来说,Android实现Banner组件的阴影效果可以使用背景资源,CardView或自定义Drawable的方式来实现。具体使用哪种方法则取决于具体的需求和设计要求。 ### 回答2: 在Android实现阴影效果可以使用以下几种方法: 1. 使用阴影背景图:可以创建一个包含阴影效果的背景图片,并将其设置为Banner的背景。这样可以在Banner的背景上显示出阴影效果。 2. 使用9patch图实现阴影:使用一个带有阴影效果的9patch图作为Banner的背景。9patch图是一种可以按需拉伸和平铺的图片,可以通过在特定区域绘制黑色像素,使其在Banner上显示为阴影效果。 3. 使用CardView控件:在Banner的父容器中使用CardView控件,并设置CardView的elevation属性来实现阴影效果。通过设置不同大小的elevation值,可以调整阴影的大小和深度。 4. 使用自定义绘制:可以通过在Banner的onDraw方法中使用Canvas绘制阴影效果。可以使用Paint设置阴影颜色、大小和透明度,并在绘制Banner时应用阴影效果。 以上是实现阴影效果的几种常用方法,根据具体需求选择最适合的方式。在选择方法时,可以考虑到性能、可定制性和兼容性等因素。 ### 回答3: 要在Android实现阴影效果,可以通过以下步骤: 1. 首先,在XML布局文件中定义一个Banner组件。例如:<android.support.v7.widget.AppCompatImageView android:id="@+id/banner" android:layout_width="match_parent" android:layout_height="wrap_content" /> 2. 在Java代码中找到Banner组件,并为其设置阴影效果。例如,在Activity的onCreate方法中添加以下代码: AppCompatImageView banner = findViewById(R.id.banner); banner.setBackgroundResource(R.drawable.banner_shadow); 3. 创建banner_shadow.xml文件,用来实现阴影效果。在res/drawable文件夹下创建banner_shadow.xml,并添加以下代码: <shape xmlns:android="http://schemas.android.com/apk/res/android"> <solid android:color="#FFFFFF"/> <corners android:radius="5dp" /> <padding android:left="1dp" android:top="1dp" android:right="1dp" android:bottom="1dp" /> <gradient android:startColor="#55000000" android:endColor="#00000000" android:angle="270" /> </shape> 其中,solid定义了背景色,corners定义了圆角效果,padding定义了内边距,gradient定义了渐变色效果。 4. 最后,运行应用程序,你会看到Banner显示出一个带有阴影的效果。 这是一种简单的方法来实现Android中的Banner组件添加阴影效果。你也可以根据自己的需求进行调整,并尝试不同的阴影效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值