在 pagerslidingtabstrip 中禁用页面滚动

make page scroll disable in pagerslidingtabstrip

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

  1. 章节分析
  2. 排名明智的分析

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

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

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

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

创建一个单独的 class 应该扩展 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"
    />

然后在你的 activity 中,将你的 FragmentPagerAdapter 设置为这个 viewPager:

mViewPager.setAdapter(YourFragmentPagerAdapter)

这是我的解决方案.... 我对我的 layout.Previously 做了细微的改动,我在每个片段上都有 2 个按钮。 现在我将那两个按钮放在父级 activity 中。这是我的 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 .