0

ネストされたフラグメントでCameraインテントを呼び出し、フラグメント内のonActivityResultでイメージを問題なく取得します。イメージを切り抜きたいので、onActivityResultで(2番目の)インテントを呼び出し、イメージをCropインテントに渡します。ただし、この場合はonActivityResultは呼び出されません(アプリケーションがインテントのいずれかでバックグラウンドで終了した場合にのみ有効です)。ない第1のカメラの意図のために -ネストされたフラグメントのonActivityResultの2番目のIntentを呼び出すと、onActivityResultが再びコールされません。

W/FragmentActivity: Activity result no fragment exists for who: android:fragment:0:1 

は、これが唯一の作物意図が呼び出されたときにスローされます。

@Override 
public void onActivityResult(int requestCode, int resultCode, Intent imageReturnedIntent) { 
    super.onActivityResult(requestCode, resultCode, imageReturnedIntent); 
    switch (requestCode) { 

     // Camera onActivityResult 
     case INTENT_CAMERA: 
      Toast.makeText(getActivity(), "IN CARD ONACTIVITY - CAMERA INTENT", Toast.LENGTH_LONG).show(); 
      if (resultCode == RESULT_OK) { 

       SharedPreferences getPrefs = PreferenceManager.getDefaultSharedPreferences(getActivity()); 
       String uriString = getPrefs.getString("photoUri", null); 
       if (uriString != null) { 

        Uri selectedImage = Uri.parse(uriString); 

        Intent intent = CropImage.activity(selectedImage).setAspectRatio(1, 1).setMinCropResultSize(800, 800).getIntent(getContext()); 
        startActivityForResult(intent, INTENT_CROP); 

       } else { 
        Toast.makeText(getActivity(), "ERROR", Toast.LENGTH_LONG).show(); 
       } 

      } 
      break; 

     // Crop ActivityOnResult 
     case INTENT_CROP: 
      Toast.makeText(getActivity(), "IN CARD ONACTIVITY - CROP INTENT", Toast.LENGTH_LONG).show(); 

      CropImage.ActivityResult result = CropImage.getActivityResult(imageReturnedIntent); 
      if (resultCode == RESULT_OK) { 
       Uri resultUri = result.getUri(); 
       try { 
        bitmap = MediaStore.Images.Media.getBitmap(getActivity().getContentResolver(), resultUri); 
        uploadImage(); 
       } catch (IOException e) { 
        e.printStackTrace(); 
       } 

      } else if (resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE) { 
       Exception error = result.getError(); 
      } 
    } 
} 

は、私は、ログに次の行を見つけました。第2の意図を呼び出す前にフラグメントを作成するのを待たなければなりませんか?あるいは、このような状況に対処する他の信頼できる方法がありますか?ありがとうございました!

アクティビティコード:

public class MainActivity extends AppCompatActivity { 

// Nav Drawer Variables 
private DrawerLayout mDrawer; 
private Toolbar toolbar; 
private NavigationView nvDrawer; 
private ActionBarDrawerToggle drawerToggle; 

private PrefManager prefManager; 

FragmentManager fragmentManager = getSupportFragmentManager(); 
Fragment fragment = null; 
FragmentTransaction transaction; 
String FRAGMENT_TAG; 


@Override 
protected void onCreate(Bundle savedInstanceState) { 


    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    prefManager = new PrefManager(this); 


    // Set a Toolbar to replace the ActionBar. 
    toolbar = (Toolbar) findViewById(R.id.toolbar); 
    setSupportActionBar(toolbar); 

    // Set navigation view 
    NavigationView navigationView = (NavigationView) findViewById(R.id.nvView); 
    View v = navigationView.getHeaderView(0); 

    // Find drawer view 
    mDrawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    drawerToggle = setupDrawerToggle(); 

    // Tie DrawerLayout events to the ActionBarToggle 
    mDrawer.addDrawerListener(drawerToggle); 

    // Find drawer view 
    nvDrawer = (NavigationView) findViewById(R.id.nvView); 
    // Setup drawer view 
    setupDrawerContent(nvDrawer); 


    //Set Progress Bar Invisible 
    FrameLayout progressFrame = (FrameLayout) findViewById(R.id.progressFrame); 
    progressFrame.setVisibility(View.GONE); 



    // Switch between hamburger and back button 
    getSupportFragmentManager().addOnBackStackChangedListener(new FragmentManager.OnBackStackChangedListener() { 
     @Override 
     public void onBackStackChanged() { 
      if (getSupportFragmentManager().getBackStackEntryCount() > 0) { 
       getSupportActionBar().setDisplayHomeAsUpEnabled(true); // show back button 
       toolbar.setNavigationOnClickListener(new View.OnClickListener() { 
        @Override 
        public void onClick(View v) { 
         onBackPressed(); 
        } 
       }); 
      } else { 
       //show hamburger 
       getSupportActionBar().setDisplayHomeAsUpEnabled(false); 
       drawerToggle.syncState(); 
       toolbar.setNavigationOnClickListener(new View.OnClickListener() { 
        @Override 
        public void onClick(View v) { 
         mDrawer.openDrawer(GravityCompat.START); 
        } 
       }); 
      } 
     } 
    }); 

    // Handle Fragments 
    if (savedInstanceState != null) { 

     fragment = fragmentManager.getFragment(savedInstanceState, "fragment"); 
     transaction = fragmentManager.beginTransaction(); 
     transaction.replace(R.id.flContent, fragment, FRAGMENT_TAG).commit(); 
    } else { 
     // Insert the inital fragment 
     Class fragmentClass = Fragment1.class; 
     FRAGMENT_TAG = "FRAGMENT_1"; 
     try { 
      fragment = (Fragment) fragmentClass.newInstance(); 

      transaction = fragmentManager.beginTransaction(); 
      transaction.replace(R.id.flContent, fragment, FRAGMENT_TAG).commit(); 
     } catch (InstantiationException e) { 
      e.printStackTrace(); 
     } catch (IllegalAccessException e) { 
      e.printStackTrace(); 
     } 
    } 

} 


private ActionBarDrawerToggle setupDrawerToggle() { 
    return new ActionBarDrawerToggle(this, mDrawer, toolbar, R.string.drawer_open, R.string.drawer_close); 
} 

private void setupDrawerContent(NavigationView navigationView) { 
    navigationView.setNavigationItemSelectedListener(
      new NavigationView.OnNavigationItemSelectedListener() { 
       @Override 
       public boolean onNavigationItemSelected(MenuItem menuItem) { 
        selectDrawerItem(menuItem); 
        return true; 
       } 
      }); 
} 

public void selectDrawerItem(MenuItem menuItem) { 
    // Create a new fragment and specify the fragment to show based on nav item clicked 

    Class fragmentClass = null; 
    switch (menuItem.getItemId()) { 
     case R.id.nav_home: 
      FRAGMENT_TAG = "FRAGMENT_1"; 
      fragmentClass = Fragment1.class; 
      break; 
     case R.id.nav_mychallenges: 
      FRAGMENT_TAG = "FRAGMENT_2"; 
      fragmentClass = Fragment2.class; 
      break; 
     case R.id.nav_feedback: 
      FRAGMENT_TAG = "FRAGMENT_3"; 
      fragmentClass = Fragment3.class; 
      break; 
     default: 
FRAGMENT_TAG = "FRAGMENT_1"; 
      fragmentClass = Fragment1.class; 
    } 
    try { 
     fragment = (Fragment) fragmentClass.newInstance(); 

    } catch (Exception e) { 
     e.printStackTrace(); 
    } 

    // Insert the fragment by replacing any existing fragment 

    transaction = fragmentManager.beginTransaction(); 
    //transaction.addToBackStack(null); 
    transaction.replace(R.id.flContent, fragment, FRAGMENT_TAG).commit(); 

    // Highlight the selected item has been done by NavigationView 
    menuItem.setChecked(true); 
    // Set action bar title 
    setTitle(menuItem.getTitle()); 
    // Close the navigation drawer 
    mDrawer.closeDrawers(); 
} 

@Override 
public void onBackPressed() { 
    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    if (drawer.isDrawerOpen(GravityCompat.START)) { 
     drawer.closeDrawer(GravityCompat.START); 
    } else { 
     super.onBackPressed(); 
    } 
} 


@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    if (drawerToggle.onOptionsItemSelected(item)) { 
     return true; 
    } 
    return super.onOptionsItemSelected(item); 
} 


// `onPostCreate` called when activity start-up is complete after `onStart()` 
// NOTE! Make sure to override the method with only a single `Bundle` argument 
@Override 
protected void onPostCreate(Bundle savedInstanceState) { 
    super.onPostCreate(savedInstanceState); 
    // Sync the toggle state after onRestoreInstanceState has occurred. 
    drawerToggle.syncState(); 

} 


@Override 
public void onConfigurationChanged(Configuration newConfig) { 
    super.onConfigurationChanged(newConfig); 
    // Pass any configuration change to the drawer toggles 
    drawerToggle.onConfigurationChanged(newConfig); 
} 

@Override 
protected void onResume() { 
    super.onResume(); 
} 

@Override 
protected void onSaveInstanceState(Bundle outState) { 
    super.onSaveInstanceState(outState); 

    fragmentManager.putFragment(outState, "fragment", fragmentManager.findFragmentById(R.id.flContent)); 
    Log.d("TAG", "CURRENT_FRAGMENT: " + fragmentManager.findFragmentById(R.id.flContent)); 
} 

@Override 
public void onActivityResult(int requestCode, int resultCode, Intent data) { 
    super.onActivityResult(requestCode, resultCode, data); 
} 

} 

はEDIT:

ParentFragment:

public class FragmentProcess extends Fragment { 


Fragment childFragment; 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 



    // Inflate the layout for this fragment 
    View view = inflater.inflate(R.layout.fragment_process, container, false); 
    TextView processTitle = (TextView) view.findViewById(R.id.title); 
    processTitle.setText("Title"); 
    return view; 
} 

@Override 
public void onViewCreated(View view, Bundle savedInstanceState) { 
    loadData(); 
} 

private void loadData() { 


     String url = "example.com "; 
     // Instantiate the RequestQueue. 
     // RequestQueue queue = Volley.newRequestQueue(getActivity().getApplicationContext()); 

     // Request a string response from the provided URL. 
     StringRequest stringRequest = new StringRequest(Request.Method.GET, url, new Response.Listener<String>() { 
      @Override 
      public void onResponse(String response) { 
       // Display the first 500 characters of the response string. 
       subChallengesString = response; 

       insertNestedFragment(); 


      } 
     }, new Response.ErrorListener() { 
      @Override 
      public void onErrorResponse(VolleyError error) { 

      } 
     }); 
     MySingleton.getInstance(getActivity()).addToRequestQueue(stringRequest); 


} 

// Embeds the child fragment dynamically 
private void insertNestedFragment() { 



    childFragment = new FragmentProcessChallengeCard(); 
    FragmentTransaction transaction = getChildFragmentManager().beginTransaction(); 
    transaction.replace(R.id.process_challenge_child_fragment, childFragment).commit(); 
} 

@Override 
public void onSaveInstanceState(Bundle outState) { 
    super.onSaveInstanceState(outState); 
    //Save the fragment's state here 
} 

@Override 
public void onActivityResult(int requestCode, int resultCode, Intent data) { 
    super.onActivityResult(requestCode, resultCode, data); 
    } 
} 
+0

アクティビティコードを入力できますか? –

+0

@JayminPanchal上記のアクティビティコードを – mojo

+0

に追加しましたか?cropImage Intentを正しく呼び出すのは本当ですか? –

答えて

0

使用しているライブラリでは、親アクティビティのonActivityResultメソッドが呼び出されると書かれています。あなたのonActivityResult of Parent Activityをチェックして、同じ結果をフラグメントに送るメソッドまたはインターフェイスを作成します。

@Override 
public void onActivityResult(int requestCode, int resultCode, Intent data) { 
    if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE) { 
    CropImage.ActivityResult result = CropImage.getActivityResult(data); 
    if (resultCode == RESULT_OK) { 
     Uri resultUri = result.getUri(); 
    } else if (resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE) { 
     Exception error = result.getError(); 
    } 
} 
0

あなたの活動からのフラグメントに、アクティビティの結果を渡す必要があります。

activityでこのコードを試して、機能するかどうかを確認してください。

@Override 
protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
    Fragment fragment = getSupportFragmentManager().findFragmentById(R.id.flContent); 
    fragment.onActivityResult(requestCode, resultCode, data); 
} 
+0

この方法では、子フラグメントのonActivityResult()はまったく呼び出されません。カメラの意図では初めてではありません。私の答えでは、親フラグメントのコードをいくつか追加します。多分それが問題を理解するのに役立つでしょう。 – mojo

関連する問題