sdcard에서 불러온 이미지를 다른클래스에서 수행하고 싶은데요.이미지 경로를 전달하는법에 대해서 알려주세요

(참조할만한 소스코드가 있으시면 도와주세요 ㅠㅠ)

 

도와주세요 ㅠㅠ.

 

 

package pe.kr.theeye.cameracrop;

import java.io.File;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.IntentFilter;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast;


//http://dislab.hufs.ac.kr/lab/Android/Intent_%EC%82%AC%EC%9A%A9_%EC%98%88?rdfrom=http%3A%2F%2Fdislab.hufs.ac.kr%2Fw%2Findex.php%3Ftitle%3DAndroid%2FIntent_%25EC%2582%25AC%25EC%259A%25A9_%25EC%2598%2588%26redirect%3Dno#.EB.82.B4.EC.9E.A5_.EC.82.AC.EC.A7.84_.EA.B3.A0.EB.A5.B4.EA.B8.B0_.28Image_Selection.29

public class CameraCropActivity extends Activity implements OnClickListener
{
 private static final int PICK_FROM_CAMERA = 0;
 private static final int PICK_FROM_ALBUM = 1;
 private static final int CROP_FROM_CAMERA = 2;

 private Uri mImageCaptureUri;
 private ImageView mPhotoImageView;
 private Button mButton;

 @Override
 public void onCreate(Bundle savedInstanceState)
 {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  
  mButton = (Button) findViewById(R.id.button);
  mPhotoImageView = (ImageView) findViewById(R.id.imageView1);
  
  mButton.setOnClickListener(this);
 }
 private final BroadcastReceiver mReceiver = new BroadcastReceiver()
    {

  @Override

  public void onReceive(Context context, Intent intent)
  {

   if (intent.getAction().equals(Intent.ACTION_MEDIA_SCANNER_STARTED))
    Toast.makeText(CameraCropActivity.this, "사진을 업데이트하고있습니다" ,
               Toast.LENGTH_SHORT).show();        

    else if (intent.getAction().equals(Intent.ACTION_MEDIA_SCANNER_FINISHED))
     Toast.makeText(CameraCropActivity.this, "사진이 업데이트 되었습니다" ,
               Toast.LENGTH_SHORT).show();        
    }

   };
 /**
  * 카메라에서 이미지 가져오기
  */
// private void doTakePhotoAction()
// {
//  /*
//   * 참고 해볼곳
//   * http://2009.hfoss.org/Tutorial:Camera_and_Gallery_Demo
//   * http://stackoverflow.com/questions/1050297/how-to-get-the-url-of-the-captured-image
//   * http://www.damonkohler.com/2009/02/android-recipes.html
//   * http://www.firstclown.us/tag/android/
//   */
//
////  Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
////  
////  // 임시로 사용할 파일의 경로를 생성
////  String url = "tmp_" + String.valueOf(System.currentTimeMillis()) + ".jpg";
////  mImageCaptureUri = Uri.fromFile(new File(Environment.getExternalStorageDirectory(), url));
////  
////  intent.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, mImageCaptureUri);
////  intent.putExtra("return-data", true);
////  startActivityForResult(intent, PICK_FROM_CAMERA);
// }
 
 /**
  * 앨범에서 이미지 가져오기
  */
 private void doTakeAlbumAction()
 {
  // 앨범 호출
  Intent intent = new Intent(Intent.ACTION_PICK);
  intent.setType(android.provider.MediaStore.Images.Media.CONTENT_TYPE);
  startActivityForResult(intent, PICK_FROM_ALBUM);
 }

 
 @Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data)
 {
  if(resultCode != RESULT_OK)
  {
   return;
  }

  switch(requestCode)
  {
   case CROP_FROM_CAMERA:
   {
    // 크롭이 된 이후의 이미지를 넘겨 받습니다. 이미지뷰에 이미지를 보여준다거나 부가적인 작업 이후에
    // 임시 파일을 삭제합니다.
    final Bundle extras = data.getExtras();
 
    if(extras != null)
    {
     Bitmap photo = extras.getParcelable("data");
     mPhotoImageView.setImageBitmap(photo);
     
     MediaStore.Images.Media.insertImage(getContentResolver(), photo, "title", "descripton");
     IntentFilter intentFilter = new IntentFilter(Intent.ACTION_MEDIA_SCANNER_STARTED);
         intentFilter.addAction(Intent.ACTION_MEDIA_SCANNER_FINISHED);
         intentFilter.addDataScheme("file");
         registerReceiver(mReceiver, intentFilter);

         sendBroadcast(new Intent(Intent.ACTION_MEDIA_MOUNTED, Uri.parse("file://"
                    + Environment.getExternalStorageDirectory())));
    }
 
    // 임시 파일 삭제
    File f = new File(mImageCaptureUri.getPath());
    if(f.exists())
    {
     f.delete();
    }
 
    break;
   }
 
   case PICK_FROM_ALBUM:
   {
    // 이후의 처리가 카메라와 같으므로 일단  break없이 진행합니다.
    // 실제 코드에서는 좀더 합리적인 방법을 선택하시기 바랍니다.
    
    mImageCaptureUri = data.getData();
   }
   
   case PICK_FROM_CAMERA:
   {
    // 이미지를 가져온 이후의 리사이즈할 이미지 크기를 결정합니다.
    // 이후에 이미지 크롭 어플리케이션을 호출하게 됩니다.
 
    Intent intent = new Intent("com.android.camera.action.CROP");
    intent.setDataAndType(mImageCaptureUri, "image/*");
 
    intent.putExtra("outputX", 90);
    intent.putExtra("outputY", 90);
    intent.putExtra("aspectX", 1);
    intent.putExtra("aspectY", 1);
    intent.putExtra("scale", true);
    intent.putExtra("return-data", true);
    
  //  int imgData = imageCursor.getColumnIndex(MediaStore.Images.Media.DATA);
  //  imageDataPath = imageCursor.getString(imgData);
    //this.imgPath = extras.getString("filename");
   // intent.putExtra("filename",true);
   // startActivity();
    startActivityForResult(intent, CROP_FROM_CAMERA);
 
    break;
   }
  }
 }

 @Override
 public void onClick(View v)
 {
  DialogInterface.OnClickListener cameraListener = new DialogInterface.OnClickListener()
  {
   @Override
   public void onClick(DialogInterface dialog, int which)
   {
   // doTakePhotoAction();
   }
  };
  
  DialogInterface.OnClickListener albumListener = new DialogInterface.OnClickListener()
  {
   @Override
   public void onClick(DialogInterface dialog, int which)
   {
    doTakeAlbumAction();
   }
  };
  
  DialogInterface.OnClickListener cancelListener = new DialogInterface.OnClickListener()
  {
   @Override
   public void onClick(DialogInterface dialog, int which)
   {
    dialog.dismiss();
   }
  };
  
  new AlertDialog.Builder(this)
   .setTitle("업로드할 이미지 선택")
   .setPositiveButton("사진촬영", cameraListener)
   .setNeutralButton("앨범선택", albumListener)
   .setNegativeButton("취소", cancelListener)
   .show();
 }
}

 

공지사항 다 읽었음.