我们可以在PagerSlidingTabStrip中禁用页面滑动吗?我正在使用PagerSlidingTabStrip,其中选项卡是在我的示例中动态创建的。在每个片段上都有两个按钮
我想要的是当用户点击排名明智的分析时滑动应该禁用并且标签得到隐藏,当点击章节明智的分析标签应该再次可见并且滑动也应该启用。怎么做到这一点?选项卡隐藏和显示工作正常,但无法进行幻灯片禁用。
答案 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
会隐藏Tabs
,ViewPager
并向{LinerLayout
添加一个片段1}}。