ViewPager 中的多面板片段

4

我目前正在开发一款类似“电子书”播放器的应用程序。在阅读了许多与片段相关的教程后,我决定采用“Fragment / Viewpager”方法。

更具体地说,我决定遵循Linden Darling的嵌套片段教程https://plus.google.com/100467024733771542884/posts/24HcFW5hEiV。

我为每个单独的书页创建了一个“WebView”片段,具有自己的布局。因此,如果我的书包含6页,则会有BookPage1Fragment、BookPage2Fragment、BookPage3Fragment、BookPage4Fragment、BookPage5Fragment、BookPage6Fragment等。我成功地将它们放入了Viewpager中,所以所有刷屏片段等工作正常。问题是,屏幕上只有一个片段可见。我希望在大设备和横向方向上运行应用程序时可以显示两个片段(多面板),而在较小设备或纵向视图上运行时可以显示单面板(一次只显示一个片段)。我想显示一个由一个左片段和一个右片段组成的双面板布局。

请参见以下代码:

public class ParentFragment extends Fragment {

public static final String TAG = ParentFragment.class.getSimpleName();

public static ParentFragment newInstance() {
return new ParentFragment();
}

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setRetainInstance(true);
}

@Override

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

@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
super.onViewCreated(view, savedInstanceState);

ViewPager mViewPager = (ViewPager) view.findViewById(R.id.viewPager);
mViewPager.setAdapter(new MyAdapter(getChildFragmentManager()));
}

public static class MyAdapter extends FragmentPagerAdapter {
public MyAdapter(FragmentManager fm) {
    super(fm);
}

@Override
public int getCount() {
    return 6;
}

/*

@Override
public Fragment getItem(int position) {
    Bundle args = new Bundle();
    args.putInt(TextViewFragment.POSITION_KEY, position);
    return TextViewFragment.newInstance(args);
}


*/

@Override
public Fragment getItem(int position) {
    switch (position) {
    case 0:
        return new BookPage1Fragment();
    case 1:
        return new BookPage2Fragment();
    case 2:
        return new BookPage3Fragment();
    case 3:
        return new BookPage4Fragment();
    case 4:
        return new BookPage5Fragment();
    case 5:
        return new BookPage6Fragment();


    default:
        return getItem(0);
    }
}


@Override
public CharSequence getPageTitle(int position) {
    return "Fragment # " + position;
}

}

}

基本上,当处于横屏模式时,会出现两个片段,而在纵向模式下一次只会出现一个片段,就如同开发者博客描述的那样 http://android-developers.blogspot.in/2011/02/android-30-fragments-api.html,但嵌入了一个视图页。这是我的主要布局。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout> xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >

<android.support.v4.view.ViewPager
    android:id="@+id/pager"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
     />

</RelativeLayout>

这是我的webview片段的内容:
public class WebViewFragment extends Fragment {

 @SuppressLint("SetJavaScriptEnabled")
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View mainView = (View) inflater.inflate(R.layout.fragment_web, container, false);
        WebView myWebView = (WebView) mainView.findViewById(R.id.webview);
        myWebView.loadUrl("file:///android_asset/Ebook-001.html");


        myWebView.setWebViewClient(new MyWebViewClient());
        myWebView.getSettings().setBuiltInZoomControls(true); 
        myWebView.getSettings().setJavaScriptEnabled(true);
        myWebView.getSettings().setSupportZoom(true);
        myWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);   
        myWebView.getSettings().setAllowFileAccess(true); 
        myWebView.getSettings().setDomStorageEnabled(true);
        myWebView.getSettings().setUseWideViewPort(true);
        myWebView.getSettings().setLoadWithOverviewMode(true);
            return mainView;
        }

    }

这是我的WebView片段布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >

<WebView
    android:id="@+id/webview"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" />

</LinearLayout>

所以总结一下,我想要:

1:在横屏模式下,在viewpager中显示两个片段,在竖屏模式下只显示一个。

2:使用一个活动来适应所有设备尺寸,并在运行时决定是否组合布局中的片段(创建多面板设计)或交换片段(创建单面板设计)。

希望这一切都说得通!感谢您提供任何建议...

1个回答

1
你需要为横屏模式创建一个布局文件。在res文件夹中创建一个名为layout-land的文件。在该文件夹中创建与布局文件中相同名称的布局。当屏幕切换到横屏模式时,Android会自动访问它。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接