ใช้ FragmentTabHost กับ ViewPager

ฉันต้องการสร้างอินเทอร์เฟซแท็บแบบปัดโดยใช้ FragmentTabHost กับ ViewPager จนถึงตอนนี้ฉันมี Fragments ที่จะเลื่อน สิ่งเดียวที่เกิดขึ้นคือชิ้นส่วนต่างๆ สามารถเลื่อนไปด้านหลังแท็บที่ ปิดใช้งาน/ติดอยู่ และไม่ทำงาน ฉันจะทำให้แท็บ FragmentTabHost ทำงานร่วมกับ ViewPager สำหรับการปัดระหว่างแท็บได้อย่างไร

ฉันลองใช้ FragmentTabHost โดยไม่มีวิวเพจเจอร์ มันใช้งานได้ดี แต่มันใช้งานไม่ได้กับวิวเพจเจอร์

นี่คือภาพหน้าจอที่มีลักษณะดังนี้: ป้อนคำอธิบายรูปภาพที่นี่

ซอร์สโค้ด 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();
    }

}


}

รหัสเอ็กซ์เอ็มแอล:

<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>

comment
คุณปฏิบัติอย่างไร? ฉันต้องการทำแฟรกเมนต์แท็บโฮสต์ด้วยโปรแกรมดูเพจเจอร์ แต่ไม่สามารถหาตัวอย่างได้   -  person Prashanth Debbadwar    schedule 08.01.2016
comment
ด้วยวิธีการนี้ ชิ้นส่วนต่างๆ จะถูกเพิ่มสองครั้ง หนึ่งเพราะ FragmentTabHost และอีกอันเพราะ ViewPager Adapter   -  person Shan Xeeshi    schedule 18.09.2018


คำตอบ (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

                }
            });

ปัญหาคือเมื่อคุณปัดส่วนต่างๆ ไม่มีทางที่แท็บจะรู้ได้ โดยการระบุผ่านโค้ดด้านบน คุณก็สามารถทำงานนี้ได้ ฉันมีปัญหาเดียวกัน แต่แก้ไขได้ด้วยสิ่งนี้ หวังว่านี่จะช่วยได้

person karan vs    schedule 01.02.2015