在 pagerslidingtabstrip 中禁用页面滚动
make page scroll disable in pagerslidingtabstrip
我们可以在 PagerSlidingTabStrip 中禁用页面滑动吗?我正在使用 PagerSlidingTabStrip,在我的示例中动态创建选项卡。每个片段上都有两个按钮
- 章节分析
- 排名明智的分析
我想要的是当用户点击排名明智的分析时,滑动应该被禁用并且标签被隐藏,当点击章节明智的分析标签应该再次可见并且滑动也应该启用。如何做到这一点?选项卡隐藏和显示工作正常,但无法禁用幻灯片。
扩展 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
将隐藏 Tabs
、ViewPager
并添加一个片段到LinerLayout
.
我们可以在 PagerSlidingTabStrip 中禁用页面滑动吗?我正在使用 PagerSlidingTabStrip,在我的示例中动态创建选项卡。每个片段上都有两个按钮
- 章节分析
- 排名明智的分析
我想要的是当用户点击排名明智的分析时,滑动应该被禁用并且标签被隐藏,当点击章节明智的分析标签应该再次可见并且滑动也应该启用。如何做到这一点?选项卡隐藏和显示工作正常,但无法禁用幻灯片。
扩展 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
将隐藏 Tabs
、ViewPager
并添加一个片段到LinerLayout
.