0

フラグメントに関する 1 つの問題で立ち往生しています。さまざまなフラグメントを切り替えて、上部にメニューを表示したいだけです-非常に標準的だと思います-smth。ここみたいに:

ここに画像の説明を入力

この目的のために、PageAdapter をセットアップします (ここで、SMartFragmentStatePageAdapter は FragmentStatePagerAdapter から派生したものです)。

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.app.FragmentStatePagerAdapter;

class ViewPagerAdapter extends SmartFragmentStatePagerAdapter {


    public ViewPagerAdapter(FragmentManager manager) {
        super(manager);
    }

    @Override
    public Fragment getItem(int position) {        
        return ArrayListFragment.newInstance(position);
    }

    @Override
    public int getCount() {
        return categories.length;        
    }

    @Override
    public CharSequence getPageTitle(int position) {
        return categories[position];
    }
}

メイン クラスでページ アダプターを初期化します。

viewPager = (ViewPager) findViewById(R.id.pager);
SmartFragmentStatePagerAdapter adapter = new ViewPagerAdapter(getSupportFragmentManager());
viewPager.setAdapter(adapter);

そして、私の ArrayFragment クラスは次のようになります。

import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.support.v4.app.ListFragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;

import java.util.Collections;

public class ArrayListFragment extends ListFragment {
    int mNum;

    /**
     * Create a new instance of CountingFragment, providing "num"
     * as an argument.
     */
    public static ArrayListFragment newInstance(int num) {
        ArrayListFragment f = new ArrayListFragment();

        // Supply num input as an argument.
        Bundle args = new Bundle();
        args.putInt("num", num);
        f.setArguments(args);

        return f;
    }

    /**
     * When creating, retrieve this instance's number from its arguments.
     */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mNum = getArguments() != null ? getArguments().getInt("num") : 1;
    }

    /**
     * The Fragment's UI is just a simple text view showing its
     * instance number.
     */
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View v = inflater.inflate(R.layout.fragment_pager_list, container, false);
        View tv = v.findViewById(R.id.text);
        int page = getArguments().getInt("num", -1);
        ((TextView)tv).setText("Fragment #" + mNum);
        return v;
    }

    @Override
    public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        setListAdapter(new ArrayAdapter<String>(getActivity(),
                android.R.layout.simple_list_item_1, Collections.singletonList("test1")));
    }

    @Override
    public void onListItemClick(ListView l, View v, int position, long id) {
        Log.i("FragmentList", "Item clicked: " + id);
    }
}

ここで、PageAdapter の見出しタイトルを表示するには、レイアウト ファイルに「PagerTabStrip」を追加する必要があるため、メイン クラスのレイアウト ファイルは次のようになります。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:padding="4dip"
    android:gravity="center_horizontal"
    android:layout_width="match_parent" android:layout_height="match_parent">

    <android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="0px"
        android:layout_weight="1">
        <android.support.v4.view.PagerTabStrip
            android:layout_width="match_parent"
            android:layout_height="match_parent">
        </android.support.v4.view.PagerTabStrip>
    </android.support.v4.view.ViewPager>

        <LinearLayout android:orientation="horizontal"
        android:gravity="center" android:measureWithLargestChild="true"
        android:layout_width="match_parent" android:layout_height="wrap_content"
        android:layout_weight="0">
        <Button android:id="@+id/goto_first"
            android:layout_width="wrap_content" android:layout_height="wrap_content"
            android:text="first">
        </Button>
        <Button android:id="@+id/goto_last"
            android:layout_width="wrap_content" android:layout_height="wrap_content"
            android:text="last">
        </Button>
    </LinearLayout>
</LinearLayout>

問題は、PagerTabStrip を使用しているときに、ArrayFragment の内容が表示されないことです。

PagerTabStrip の場合:

ここに画像の説明を入力

PagerTabStrip を使用しない場合:

ここに画像の説明を入力

そのため、PagerTabStrip がないとコンテンツが表示され、その理由がわかりません。

ここで、解決策は getSupportFragmentManager() の代わりに getChildFragmentManager() を使用することである可能性があることを読みました。しかし、この関数は、メイン クラスが Fragment から派生している場合にのみ使用できますが、FragmentActivity から派生しているため、これは解決策にはなりません。

何か案は?

4

1 に答える 1

0

そのうちに、何がうまくいかなかったのかがわかりました。

レイアウトファイルに問題があるに違いないと確信していましたが、実際にそうでした。おそらく、私は android:layout_height="0px" を設定すべきではありませんでした :) 休憩なしで何時間ものハッキングの結果。

したがって、ViewPager の小さな適応により、それは魅力のように機能しました。

<android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1">
            <android.support.v4.view.PagerTabStrip
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="top"
            android:paddingBottom="10dp"
            android:paddingTop="10dp">
        </android.support.v4.view.PagerTabStrip>
    </android.support.v4.view.ViewPager>

すでに分析を開始している皆さん、ありがとうございます。

于 2020-06-13T22:11:29.787 に答える