recherche

Maison  >  Questions et réponses  >  le corps du texte

android - 如何将viewpager的图片与状态栏沉侵

如何将viewpager的图片与状态栏沉侵,这该如何做呢???我这里的viewpager不是全屏的,而是占屏幕的1/4.

巴扎黑巴扎黑2772 Il y a quelques jours512

répondre à tous(1)je répondrai

  • 阿神

    阿神2017-04-17 17:41:21

    以前刚好做过一个半成品的app,主页用的刚刚好是题主要的效果.我先抛链接了:
    点这里,里面有注释的

    StatusBarUtil.setTransparent(MainActivity.this);
    //然后动态的改变Activity的背景就可以实现了

    我来更新了:
    先看布局吧(这里给我这里的示例):

    <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="@drawable/bg_saber_q"
        tools:context="didikee.com.demoapk.activity.StatuBarActivity">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
            <FrameLayout
                android:id="@+id/bg_main"
                android:layout_width="match_parent"
                android:layout_height="400dp"
                android:background="@drawable/meinv">
            //我要把这个 meinv 变为沉浸状态栏,注意层级
            </FrameLayout>
            <TextView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:textSize="50sp"
                android:textColor="@color/orange"
                android:gravity="center"
                android:text="哈哈哈"/>
        </LinearLayout>
    </FrameLayout>

    然后修改 StatusBarUtil里的方法(注意层级):

    private static void setRootView(Activity activity) {
            ViewGroup rootView = (ViewGroup) ((ViewGroup) activity.findViewById(android.R.id.content)).getChildAt(0);
    
            ViewGroup childAt = (ViewGroup) rootView.getChildAt(0);
            ViewGroup childAt1 = (ViewGroup) childAt.getChildAt(0);
            //childAt1 这个就是有美女背景图的那个FrameLayout,也是ViewGroup嘛
            childAt1.setFitsSystemWindows(true);
            childAt1.setClipToPadding(true);
        }

    demo图:

    具体你的项目是什么效果你自己微调吧

    -----再更新:
    轮播有OnPageChangeListener();动态的设置就可以了

    / 2016-10-20 更新答案 */

    PS:可能题主已经走了,但是还是写下一下更新,今天碰到类似的需求

    1. Activity 要继承 AppCompatActivity.
      2.

        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            requestWindowFeature(Window.FEATURE_NO_TITLE);
            setContentView(R.layout.xxxx);
            setBarStyle();
            init();
        }
        public void setBarStyle() {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
                // 设置状态栏透明
                getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            }
        }
        //.....
    1. 这个时候你的状态栏你就可以使用了.你可以在状态栏填充一个View然后按需求改变这个View的背景透明度

    我的 是用ScrollView去做的,所以我监听滚动的距离,贴上我的处理:

    mSScrollView.setOnScrollListener(new SScrollView.OnScrollChangedListener() {
                @Override
                public void onScrollChanged(int x, int y, int oldX, int oldY) {
                    //状态栏透明度回调
                    final int height = mFLViewpagerHeight - mTitleHeight;
                    if (y <= 0) {   //设置标题的背景颜色
                        mVGTitle.setBackgroundColor(Color.argb((int) 0, 255,255,255));
                        mTvTitleMiddle.setTextColor(Color.argb((int) 0, 46,46,46));
                        //这是填充在状态栏的View
                        mStatusBar.setBackgroundColor(Color.argb((int) 0, 204,204,204));
    
                        mIvTitleLeft.setImageResource(R.drawable.ic_arrow_left_white);
                        mIvTitleShare.setImageResource(R.drawable.ic_share_pure);
                    } else if (y > 0 && y <= height) { //滑动距离小于banner图的高度时,设置背景和字体颜色颜色透明度渐变
                        float scale = (float) y / height;
                        float alpha = (255 * scale);
                        mTvTitleMiddle.setTextColor(Color.argb((int) alpha, 46,46,46));
                        mVGTitle.setBackgroundColor(Color.argb((int) alpha, 255,255,255));
                        mStatusBar.setBackgroundColor(Color.argb((int) alpha, 204,204,204));
    
                        mIvTitleLeft.setImageResource(R.drawable.ic_arrow_left_white);
                        mIvTitleShare.setImageResource(R.drawable.ic_share_pure);
                    } else {    //滑动到banner下面设置普通颜色
                        mVGTitle.setBackgroundColor(Color.argb((int) 255, 255,255,255));
                        mTvTitleMiddle.setTextColor(Color.argb((int) 255, 46,46,46));
                        mStatusBar.setBackgroundColor(Color.argb((int) 255, 204,204,204));
                        mIvTitleLeft.setImageResource(R.drawable.ic_left_arrow_dark);
                        mIvTitleShare.setImageResource(R.drawable.ic_share_dark);
    
                    }

    不知道这个能放视频吗,我用studio录了一个demo,你看看是不是可以实现你的效果.截图传图太慢了
    http://oahzrw11n.bkt.clouddn....

    répondre
    0
  • Annulerrépondre