2016-11-17 70 views
0

我使用的标签库为SmartTabLayout - ogaclejapan。我想在父滑动选项卡的一个选项卡内添加一个滑动选项卡。但是当我这样做时,我看不到第二个滑动标签。在标签页内添加SlidingTab

参考图像First is the parent sliding tab. And in 'trains' I am adding another same sliding tab

这里是一个包含父滑动翼片在MainActivity。

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:paddingLeft="@dimen/activity_horizontal_margin" 
android:paddingRight="@dimen/activity_horizontal_margin" 
android:paddingTop="@dimen/activity_vertical_margin" 
android:paddingBottom="@dimen/activity_vertical_margin" 

android:id="@+id/root" 
tools:context="com.virtualsquadz.letsgo.MainActivity"> 
<RelativeLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_alignParentTop="true" 
    android:id="@+id/topBar" 
    android:layout_marginTop="@dimen/_16sdp" 
    android:paddingBottom="@dimen/_5sdp"> 
    <ImageButton 
     android:layout_width="wrap_content" 
     android:id="@+id/backButton" 
     android:layout_height="wrap_content" 
     android:src="@drawable/back_0" 
     android:background="@null" 
     android:layout_alignParentLeft="true" 
     /> 
    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:id="@+id/title_transport" 
     android:text="Getting Around" 
     style="@style/title_transport" 
     android:paddingTop="@dimen/_2sdp" 
     android:layout_centerInParent="false" 
     android:layout_centerHorizontal="true" 
     /> 

</RelativeLayout> 
<com.ogaclejapan.smarttablayout.SmartTabLayout 
    android:id="@+id/viewpagertab" 
    android:layout_below="@id/topBar" 
    android:layout_width="match_parent" 
    android:layout_height="48dp" 
    app:stl_indicatorAlwaysInCenter="false" 
    app:stl_indicatorWithoutPadding="false" 
    app:stl_indicatorInFront="false" 
    app:stl_indicatorInterpolation="smart" 
    app:stl_indicatorGravity="bottom" 
    app:stl_indicatorColor="#40C4FF" 
    app:stl_indicatorThickness="4dp" 
    app:stl_indicatorWidth="auto" 
    app:stl_indicatorCornerRadius="2dp" 
    app:stl_overlineColor="#4D000000" 
    app:stl_overlineThickness="0dp" 
    app:stl_underlineColor="#4D000000" 
    app:stl_underlineThickness="1dp" 
    app:stl_dividerColor="#4D000000" 
    app:stl_dividerThickness="1dp" 
    app:stl_defaultTabBackground="?attr/selectableItemBackground" 
    app:stl_defaultTabTextAllCaps="true" 
    app:stl_defaultTabTextColor="@color/flight_white" 
    app:stl_defaultTabTextSize="@dimen/_12sdp" 
    app:stl_defaultTabTextHorizontalPadding="@dimen/_16sdp" 
    app:stl_defaultTabTextMinWidth="0dp" 
    app:stl_distributeEvenly="true" 
    app:stl_clickable="true" 
    app:stl_titleOffset="24dp" 
    app:stl_drawDecorationAfterTab="false" 
    /> 

<android.support.v4.view.ViewPager 
    android:id="@+id/viewpager" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_below="@id/viewpagertab" 
    android:layout_marginTop="@dimen/_5sdp" 
    /> 


</RelativeLayout> 

MainActivity.java

SmartTabLayout viewPagerTab = (SmartTabLayout)  findViewById(R.id.viewpagertab); 
    ViewPager viewPager=(ViewPager)findViewById(R.id.viewpager) ; 

    ViewPagerItemAdapter adapter = new ViewPagerItemAdapter(ViewPagerItems.with(this) 
      .add(R.string.transportOption1, R.layout.activity_flights) 
      .add(R.string.transportOption2, R.layout.activity_train) 
      .add(R.string.transportOption3, R.layout.activity_buses) 
      .add(R.string.transportOption4, R.layout.activity_cars) 
      .create()); 

    viewPager.setAdapter(adapter); 
    viewPagerTab.setViewPager(viewPager); 

与之相似,我设计的 '火车' 内train.java

SmartTabLayout viewPagerTab = (SmartTabLayout) findViewById(R.id.viewpagertab2); 
    ViewPager viewPager=(ViewPager)findViewById(R.id.viewpager2) ; 

    ViewPagerItemAdapter adapter = new ViewPagerItemAdapter(ViewPagerItems.with(this) 
      .add(R.string.trainSearchOption1, R.layout.trainsearchoption1) 
      .add(R.string.trainSearchOption2, R.layout.trainsearchoption2) 
      .create()); 

    viewPager.setAdapter(adapter); 
    viewPagerTab.setViewPager(viewPager); 

我试图找到从here解决方案。但不幸的是我找不到答案。如果你想知道哪个ViewPager应该被调用,如果它们是嵌套的,那么以一个情况为例 - 当左/右翻转时以及当我们分别处于子视图页面的左/右端时,则调用第一个子视图页面,然后父视图呼叫器被呼叫。或者我们也可以点击父母的标签来改变它。

回答

0

Google Material Design准则不允许使用嵌套选项卡。这是一个糟糕的编程习惯。

强烈建议修改您的用户界面以符合Google的设计指南。

+0

你可以建议一个替代方案 – Swarnveer

+0

替代品是基于你的应用程序的要求。这取决于你想要你的应用程序做什么。您可以添加其他漂亮的解决方法,如下拉菜单,按钮,网格项等。完全取决于您的应用程序要求。 – AlphaQ