#android #android-fragments #android-viewpager #android-fragmentactivity #fragment-tab-host
#Android #android-фрагменты #android-viewpager #android-фрагментактивность #фрагмент-вкладка-хост
Вопрос:
Я хочу создать интерфейс вкладки прокрутки, используя a FragmentTabHost
с a ViewPager
. До сих пор я заставлял фрагменты скользить. Единственное, что происходит, это то, что фрагменты могут скользить за вкладки, которые отключены / застряли и не работают. Как я могу заставить вкладки FragmentTabHost работать с ViewPager для переключения между вкладками?
Я попытался использовать FragmentTabHost без viewpager, он работает нормально, но он просто не работает с viewpager.
вот скриншот того, как это выглядит:
Основной исходный код Java:
import java.util.List;
import java.util.Vector;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.app.FragmentTabHost;
import android.support.v4.view.ViewPager;
public class MainActivity extends FragmentActivity {
private FragmentTabHost mTabHost;
private ViewPager pager;
private MyPagerAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mTabHost = (FragmentTabHost)findViewById(android.R.id.tabhost);
pager = (ViewPager) findViewById(R.id.viewpager);
List<Fragment> fragments = new Vector<Fragment>();
fragments.add(Fragment.instantiate(this, BatteryFragment.class.getName()));
fragments.add(Fragment.instantiate(this, DeviceFragment.class.getName()));
fragments.add(Fragment.instantiate(this, NetworkFragment.class.getName()));
adapter = new MyPagerAdapter(getSupportFragmentManager(), fragments);
pager.setAdapter(adapter);
mTabHost.setup(this, getSupportFragmentManager(), R.id.realtabcontent);
mTabHost.addTab(mTabHost.newTabSpec("battery").setIndicator("Battery",
getResources().getDrawable(R.drawable.ic_battery_tab)),
BatteryFragment.class, null);
mTabHost.addTab(mTabHost.newTabSpec("network").setIndicator("Network",
getResources().getDrawable(R.drawable.ic_network_tab)),
NetworkFragment.class, null);
mTabHost.addTab(mTabHost.newTabSpec("device").setIndicator("Device",
getResources().getDrawable(R.drawable.ic_device_tab)),
DeviceFragment.class, null);
}
public class MyPagerAdapter extends FragmentPagerAdapter {
private List<Fragment> fragments;
public MyPagerAdapter(FragmentManager fm, List<Fragment> fragments) {
super(fm);
this.fragments = fragments;
}
@Override
public Fragment getItem(int arg0) {
// TODO Auto-generated method stub
return this.fragments.get(arg0);
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return this.fragments.size();
}
}
}
XML-код:
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TabWidget
android:id="@android:id/tabs"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="0"/>
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_weight="0"/>
<FrameLayout
android:id="@ id/realtabcontent"
android:layout_width="match_parent"
android:layout_height="0dp" />
<android.support.v4.view.ViewPager
android:id="@ id/viewpager"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="1"/>
</LinearLayout>
</android.support.v4.app.FragmentTabHost>
Комментарии:
1. Как вы это реализовали? Я хочу сделать fragmenttabhost с viewpager, но не могу найти никаких образцов.
2. При таком подходе фрагменты добавляются два раза. Один из-за FragmentTabHost и один из-за адаптера ViewPager.
Ответ №1:
добавьте в свой код следующее:
pager.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int arg0) {
// TODO Auto-generated method stub
mTabHost.setCurrentTab(arg0);
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
});
проблема в том, что когда вы проводите пальцем по фрагментам, вкладки не могут узнать об этом, указав это в приведенном выше коде, вы можете заставить это работать.
у меня была такая же проблема, но я решил ее с помощью этого.Надеюсь, это поможет.