Nabin, 당신은 AsyncTask
에서 이미지 처리를 할 수있는 대답으로, 나는 당신을 위해 작은 예제를 만들어 :
public class MainActivity extends AppCompatActivity {
public static final int PICK_IMAGE = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent();
intent.setType("image/*");
intent.setAction(Intent.ACTION_GET_CONTENT);
startActivityForResult(Intent.createChooser(intent, "Select Picture"), PICK_IMAGE);
}
});
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == PICK_IMAGE) {
Uri imagePath = data.getData();
new LoadImageDataTask(imagePath).execute();
}
}
private class LoadImageDataTask extends AsyncTask<Void, Void, Bitmap> {
private Uri imagePath;
LoadImageDataTask(Uri imagePath) {
this.imagePath = imagePath;
}
@Override
protected Bitmap doInBackground(Void... params) {
try {
InputStream imageStream = getContentResolver().openInputStream(imagePath);
return BitmapFactory.decodeStream(imageStream);
} catch (FileNotFoundException e) {
Toast.makeText(MainActivity.this, "The file " + imagePath + " does not exists",
Toast.LENGTH_SHORT).show();
}
return null;
}
@Override
protected void onPostExecute(Bitmap bitmap) {
super.onPostExecute(bitmap);
Toast.makeText(MainActivity.this, "I got the image data, with size: " +
Formatter.formatFileSize(MainActivity.this, bitmap.getByteCount()),
Toast.LENGTH_SHORT).show();
}
}
}
백그라운드에서 작업을하고, 동결에서 응용 프로그램을 방지 할 수 있습니다. 나는 60MB 크기의 이미지를 아주 빨리 선택할 수도 있습니다.
"사용자가 선택한 이미지의 경로 만 가져오고 싶습니다."- 경로가 없습니다. 그 외에도 [mcve]를 제공해주십시오. – CommonsWare
당신이'onActivityResult'에서하고 싶은 것을 보여줄 수 있습니까? –