viewPager 的可滑動 Title

有三種方式:java

1. 系統提供的titlecanvas

缺點:標題在viewpager的滑動過程當中也會滑動ide

實現:在ViewPager佈局中添加 PagerTabStrip 或者是 PagerTitleStrip 便可(二者選一個)佈局

2. 自定義 Title 佈局爲:多個TextView + 一個 ImageViewthis

3. 自定義 Title 佈局爲:一個LinearLayout 包含多個TextView ,重寫onDraw() 方法,畫出滑動塊spa

(推薦使用)blog

    public ViewPagerTitleView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        this.mContext = context;
        mPaint = new Paint();
        mPaint.setColor(context.getResources().getColor(R.color.colorAccent));
        mPaint.setStyle(Paint.Style.FILL_AND_STROKE);

        mLayout = new LinearLayout(context);
        mLayout.setOrientation(LinearLayout.HORIZONTAL);
        LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT);
        params.setMargins(0, 20, 0, 20);
        addView(mLayout, params);

        params1 = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT, 1.0f);

        setWillNotDraw(false);
    }

    public void setData() {
        for (int i = 0; i < mPager.getAdapter().getCount(); i++) {
            TextView textView = new TextView(mContext);
            textView.setTextSize(18);
            textView.setText(mPager.getAdapter().getPageTitle(i));
            textView.setGravity(Gravity.CENTER);
            textView.setLayoutParams(params1);
            final int finalI = i;
            textView.setOnClickListener(new OnClickListener() {
                @Override
                public void onClick(View v) {
                    mPager.setCurrentItem(finalI);
                }
            });
            mLayout.addView(textView);
        }
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        int width = mLayout.getWidth() / mPager.getAdapter().getCount();
        canvas.drawRect(mLayout.getLeft() + (mPosition + mDistense) * width, mLayout.getBottom(), mLayout.getLeft() + (mPosition + 1 + mDistense) * width, mLayout.getBottom() + dp(6), mPaint);
    }

    public int dp(float var0) {
        float density = 2.0f;
        return var0 == 0.0F ? 0 : (int) Math.ceil((double) (density * var0));
    }

    public void setViewPager(ViewPager pager) {
        this.mPager = pager;
        mPager.addView(new PagerTitleStrip(mContext));
        if (mPager.getAdapter() != null) {
            setData();
            mPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
                @Override
                public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                    mDistense = positionOffset;
                    mPosition=position;
                    invalidate();
                }

                @Override
                public void onPageSelected(int position) {
                }

                @Override
                public void onPageScrollStateChanged(int state) {

                }
            });
        }
    }
相關文章
相關標籤/搜索