TabLayout动态使用片段

时间:2015-12-27 23:37:51

标签: android android-fragments android-tablayout

我只是尝试使用TabLayout,我有一些问题需要了解它是如何工作的。片段对我来说也是新的。 所以这就是重点,用户启动应用程序时的第一个活动是教程。我在本教程的每个部分都使用了一个片段。更重要的是,我知道只有视图寻呼机对于用户来说已经足够我只想用标签布局来尝试它。 所以,在第一个片段中我有一个TextView和一个Button。当用户点击按钮时,我想切换到教程第二部分的第二个标签等。

现在是第一个片段:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:ext="http://schemas.android.com/apk/res-auto"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">

<TextView
    android:id="@+id/tv_tuto_first_fragment"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>

<Button
    android:layout_width="130dp"
    android:layout_height="53dp"
    android:id="@+id/valider_tuto_first_fragment"/>

</RelativeLayout>

java文件:

public class TutoFirstFragment extends Fragment {

    public TutoFirstFragment()
    {

    }

    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
    }

    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
    {
        return inflater.inflate(R.layout.tuto_first_fragment, container, false);
    }
}

名为Tutoriel的Activity上的onCreate()方法:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    replaceContentLayout(R.layout.tutorial_activity, super.CONTENT_LAYOUT_ID);

    toolbar = (Toolbar) findViewById(R.id.tutorial_toolbar);
    navigationView = (NavigationView) findViewById(R.id.nav_view);
    tabLayout = (TabLayout) findViewById(R.id.tuto_tab_layout);
    tabHost = (TabHost) findViewById(R.id.tuto_first_fragment_tabhost);
    viewPager = (ViewPager) findViewById(R.id.tuto_view_pager);

    setSupportActionBar(toolbar);
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);

    toggle = new ActionBarDrawerToggle(this, drawer, toolbar,  R.string.navigation_drawer_open, R.string.navigation_drawer_close);
    drawer.setDrawerListener(toggle);
    toggle.syncState();

    navigationView.setNavigationItemSelectedListener(this);

    setupViewPager(viewPager);
    tabLayout.setupWithViewPager(viewPager);
    tabLayout.setSelectedTabIndicatorColor(ContextCompat.getColor(context, R.color.white));

    toSecondFragment = (Button) findViewById(R.id.valider_tuto_first_fragment);
    toSecondFragment.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            tabHost.setCurrentTab(tabLayout.getSelectedTabPosition() + 1);
        }
    });
}

问题在于,我无法在活动中制作onClickListener,而且我也不了解如何以碎片形式进行操作。

感谢您的帮助,将您的知识分享给我:)

2 个答案:

答案 0 :(得分:0)

让您的片段实现OnClickListener

public class MainFragment extends Fragment implements OnClickListener

然后在片段中实现onClick方法

@Override // LISTENER
public void onClick(View v) { do your stuff there }

现在要将其侦听器分配给对象,请使用以下命令:

yourWhateverObject.setOnClickListener(this);

现在,如果您有权访问寻呼机,则可以在此处切换标签位置:

pager.setCurrentItem(position);

答案 1 :(得分:0)

您实际上想知道您的片段如何与父母活动进行通信。

最简洁的方法是在片段中定义接口,让您的活动实现它,然后覆盖onAttach(..)以设置回调。

这里有一个例子http://developer.android.com/training/basics/fragments/communicating.html#DefineInterface