1

私は ViewPager を使用しており、その中に 3 つのフラグメントがあります。

ViewPager が初めて読み込まれるときに、デフォルトですべてのフラグメントが読み込まれることを知っています。

最小は 3 つのフラグメントで、viewpager はフラグメントのすべてのライフサイクル メソッドを実行します。

私が気づいた問題:

  • ビューページャーをスワイプするたびに、選択したフラグメントはそのライフサイクル メソッドを再度呼び出しません。

  • したがって、グローバル変数に直接アクセスすることはできません。

    例: OnCreateView() で初期化された設定がある場合、そのフラグメントのインスタンスを初期化し、そのフラグメントのメソッドを呼び出すことによってアクティビティからアクセスしようとすると、NPE が発生します。

  • また、最初のロード後にフラグメントに対して onResume が呼び出されることさえありません。

私が知りたいこと:

  • onCreateView() で既に初期化した後、ビューと設定にアクセスするにはどうすればよいですか?

  • しかし、onCreateView() で初期化されたボタンの場合、クリックすると Web サービスが呼び出され、必要に応じて完全に機能します。

私は過去 3 日間からこれらの問題に固執し、何度もグーグルで検索しましたが、答えが見つかりませんでした。

どんな助けでも大歓迎です。

フラグメントコード:

 @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container,   
                  Bundle savedInstanceState) {
    View v = inflater.inflate(R.layout.activity_dth, container, false);

   preferences= 
    PreferenceManager.getDefaultSharedPreferences(getActivity());
    editor = preferences.edit();


    editAmt = (EditText) v.findViewById(R.id.editAmt);
    browsplan = (Button) v.findViewById(R.id.browsplan);


    Log.e("DTH onCreateView ",""+page);

    String fontpath = "fonts/OpenSans-Regular.ttf";
    Typeface tf = Typeface.createFromAsset(getActivity().getAssets(), 
    fontpath);

    editCustomerid.setTypeface(tf);
    editAmt.setTypeface(tf);

    token=preferences.getString("Token","-1");
    mobileNo=preferences.getString("userMobileNo","0");



    browsplan.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

          //new DTHOperator(getActivity()).execute();   HERE IT WORKS PROPERLY
        }
    });

    return v;
}

 @Override
 public void setUserVisibleHint(boolean isVisibleToUser) {
    super.setUserVisibleHint(isVisibleToUser);

    if(isVisibleToUser && isResumed()){
        new DTHOperator(getActivity()).execute();
        Toast.makeText(getActivity(),"setUserVisibleHint DTH  " 
       ,Toast.LENGTH_SHORT).show();
       }
    }

  public class DTHOperator extends AsyncTask<Context, Integer, String> {
    Context ctx;

    DTHOperator(Context ctx) {
        this.ctx = ctx;
    }

    @Override
    protected String doInBackground(Context... params) {
        List<NameValuePair> telecomdata = new ArrayList<NameValuePair>();
        String result;
        Log.d("Register Activity Token", /*preferences.getString("Token", "")*/token);

        telecomdata.add(new BasicNameValuePair("mobNo", /*preferences.getString("userMobileNo", "")*/mobileNo));
        telecomdata.add(new BasicNameValuePair("requestDate", Utilities.getApiCallTimeFormat()));
        telecomdata.add(new BasicNameValuePair("reqFrom", "APP"));
        Log.v("PostParameters", "telecomdata" + telecomdata);
        if (Connectivity.checkNetwork(ctx)) {
            result = rechargeUrl.queryRESTurlONline(ctx, "/GetDTHOperatorsService", "post", telecomdata, GenericConstants.PiPay_root);
        } else {
            result = GenericConstants.NETWORKNOTFOUND;
            displayToast("The Internet Connection appears to be offline");
        }


        return result;
    }

    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        MyProgress.show(ctx, "", "");
    }

    @Override
    protected void onPostExecute(String result) {
        super.onPostExecute(result);

        try {
            if (result != null) {
                if (result.equalsIgnoreCase(GenericConstants.NETWORKNOTFOUND)) {
                    MyProgress.CancelDialog();
                    Toast.makeText(ctx,"The Internet Connection appears to be offline",Toast.LENGTH_SHORT).show();
                    return;
                }
                String[] resArr = result.split("delimiter_");
                if (!resArr[0].equals("500")) {
                    MyProgress.CancelDialog();
                    Log.d("DTHOperator Response ::", result);
                    JSONArray jsonArray = null;
                    JSONObject object = new JSONObject(result);
                    jsonArray = object.getJSONArray("data");

                    for (int i = 0; i < jsonArray.length(); i++) {
                        if (jsonArray.getJSONObject(i).has("opName")) {
                            operator.add(jsonArray.getJSONObject(i).getString("opName"));

                            Log.d("", " Question size " + operator.size());
                        }
                    }

                    if(MyProgress.isShowingProgress())
                        MyProgress.CancelDialog();

                        editAmt.setText("2000");  // NPE HERE Also setting the value  

                } else {
                    MyProgress.CancelDialog();
                    displayToast("Failure");
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
            MyProgress.CancelDialog();
        }finally {
            if(MyProgress.isShowingProgress())
                MyProgress.CancelDialog();
        }

    }
4

3 に答える 3

2

次のオーバーライド メソッドを使用します

@Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
        if (isVisibleToUser && isResumed()) {

        }
    }

これにより、ユーザーが現在フラグメントを表示しているときに何かを呼び出すオプションが提供されます。

  • このフラグメントの UI が現在ユーザーに表示されているかどうかについて、システムにヒントを * 設定します。このヒントはデフォルトで true に設定され、フラグメント インスタンス* の状態の保存と復元の間で永続的です。
    • アプリはこれを false に設定して、フラグメントの UI が

    • スクロールして表示されないか、ユーザーに直接表示されません。
    • これは、フラグメント ライフサイクルの更新などの操作に優先順位を付けるためにシステムによって使用される場合があります。
    • またはローダーの順序付け動作。

      *
    • @param isVisibleToUser このフラグメントの UI が現在ユーザーに表示されている場合は true (デフォルト)、
    • そうでない場合は false。
于 2016-09-28T13:55:04.373 に答える
1

で使用するインスタンスを保持できFragmentsますViewPager。次に例を示します。

以下のようなメソッドをViewPagerAdapter定義しSparseArrayてオーバーライドします。

SparseArray<Fragment> registeredFragments = new SparseArray<>();

@Override
public Object instantiateItem(ViewGroup container, int position) {
    Fragment fragment = (Fragment) super.instantiateItem(container, position);
    registeredFragments.put(position, fragment);
    return fragment;
}

@Override
public void destroyItem(ViewGroup container, int position, Object object) {
    registeredFragments.remove(position);
    super.destroyItem(container, position, object);
}

public Fragment getRegisteredFragment(int position) {
    return registeredFragments.get(position);
}

そしてあなたに追加PageChangeListenerしますViewPager

viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    @Override
    public void onPageSelected(int position) {
        // Here's your fragment instance
        // You can access it's methods, variables, views etc.
        YourFragment fragment =(YourFragment)yourPagerAdapter.getRegisteredFragment(position);

    }

    @Override
    public void onPageScrollStateChanged(int state) {

    }
});

これがお役に立てば幸いです。幸運を!

編集:

Fragment's Views public を定義するか、ビューの getter メソッドを定義して、フラグメント インスタンスから次のようにアクセスできます。

public TextView mTextView;

また

private TextView mTextVieW;
public TextView getTextView(){
   return this.mTextView;
}

以下のようにアクセスできます。

TextView textView = yourFragmentInstance.mTetxView;

また

TextView textview = yourFragmentInstance.getTextView();
于 2016-09-28T13:51:06.863 に答える