在pagerslidingtabstrip中使页面滚动禁用

时间:2015-04-30 05:09:52

标签: android android-fragments pagerslidingtabstrip

我们可以在PagerSlidingTabStrip中禁用页面滑动吗?我正在使用PagerSlidingTabStrip,其中选项卡是在我的示例中动态创建的。在每个片段上都有两个按钮

  1. 章节分析
  2. 排名分析
  3. 我想要的是当用户点击排名明智的分析时滑动应该禁用并且标签得到隐藏,当点击章节明智的分析标签应该再次可见并且滑动也应该启用。怎么做到这一点?选项卡隐藏和显示工作正常,但无法进行幻灯片禁用。

3 个答案:

答案 0 :(得分:1)

扩展ViewPager并覆盖onInterceptTouchEvent()和onTouchEvent()。

@Override
public boolean onInterceptTouchEvent(MotionEvent event) {
    return false;
}

@Override
public boolean onTouchEvent(MotionEvent event) {
    return false;
}

答案 1 :(得分:1)

创建一个应该扩展ViewPager的单独类:

public class CustomViewPager extends ViewPager {

public CustomViewPager(Context context) {
    super(context);
}

public CustomViewPager(Context context, AttributeSet attrs) {
    super(context, attrs);
}

@Override
public boolean onInterceptTouchEvent(MotionEvent event) {
    // Never allow swiping to switch between pages
    return false;
}

@Override
public boolean onTouchEvent(MotionEvent event) {
    // Never allow swiping to switch between pages
    return false;
}
}

然后使用此viewPager在您的xml文件中设置如下:

<com.packagename.CustomViewPager
    android:id="@+id/view_pager"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    />

然后在您的活动中,将FragmentPagerAdapter设置为此viewPager:

mViewPager.setAdapter(YourFragmentPagerAdapter)

答案 2 :(得分:0)

这是我的解决方案...... 我的布局略有变化。以前每个片段都有2个按钮。 现在我将两个按钮放在父活动中..这是我的xml文件。

<RelativeLayout 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" >

<LinearLayout
    android:id="@+id/lintab"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >

    <com.joyoflearning.utils.PagerSlidingTabStrip
        android:id="@+id/tabs"
        android:layout_width="match_parent"
        android:layout_height="48dip"
        android:background="@drawable/background_tab" />
</LinearLayout>

<android.support.v4.view.ViewPager
    android:id="@+id/pager"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@+id/lintab"
    android:background="@drawable/background_tab"
    tools:context=".TestAnalysisActivity" />

<LinearLayout
    android:id="@+id/RankAnalysisFragment"
    android:layout_width="match_parent"
    android:layout_height="fill_parent"
    android:layout_above="@+id/linButtons"
    android:orientation="vertical" >
</LinearLayout>

<LinearLayout
    android:id="@+id/linButtons"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:background="@color/darkGray"
    android:gravity="center_horizontal"
    android:orientation="horizontal"
    android:paddingBottom="5dp"
    android:paddingTop="5dp" >

    <Button
        android:id="@+id/btnChapterWise"
        android:layout_width="wrap_content"
        android:layout_height="40dp"
        android:background="@drawable/btn_blue_bg"
        android:drawableLeft="@drawable/checkbtn_icon"
        android:drawablePadding="10dp"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:text="Chapterwise"
        android:textColor="#ffffff" />

    <Button
        android:id="@+id/btnRankWise"
        android:layout_width="wrap_content"
        android:layout_height="40dp"
        android:layout_marginLeft="10dp"
        android:background="@drawable/btn_blue_bg"
        android:drawableLeft="@drawable/uncheckbtn_icon"
        android:drawablePadding="10dp"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:text="Rankwise"
        android:textColor="#ffffff" />
</LinearLayout>

现在点击ChapterWiseAnalysis按钮会隐藏ID为RankAnalysisFragment的LinerLayout,点击RankWiseAnalysis会隐藏TabsViewPager并向{LinerLayout添加一个片段1}}。