2011-08-11 4 views
1

SD 카드에서 이미지를로드하기 위해 gridview를 만들고 싶습니다. 인터넷에서 많은 정보를 찾았지만 그렇게 할 수는 없습니다.SD 카드에서 이미지로드시 gridview 및 setImageBitmap

아래 코드를 실행하면 강제 종료됩니다.

나는 문제가 imageView.setImageBitmap(bmp);

하지만 난이 코드의 어떤 잘못을 모르는 찾을 수 있습니다.

누군가이 문제를 해결하는 데 도움이되기를 바랍니다.

public class GridActivity extends Activity { 

    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.grid_activity); 
     GridView gridview = (GridView)findViewById(R.id.GridView01);  
     gridview.setAdapter(new ImageAdapter(this));  
     gridview.setOnItemClickListener(new OnItemClickListener() {   
      public void onItemClick(AdapterView<?> parent, View v, int position, long id) {    
       Toast.makeText(GridActivity.this, "" + position, Toast.LENGTH_SHORT).show();   
       }  
      }); 
     } 

    public class ImageAdapter extends BaseAdapter {  
      File dir=new File(Environment.getExternalStorageDirectory(),"/images/bedroom"); 
      int count=dir.list().length; 
      String[] fileNames = dir.list(); 
      private Context mContext; 
     public ImageAdapter(Context c) {   
      mContext = c;  
      }  
     public int getCount() {   
      return count;  
      }  
     public Object getItem(int position) {   
      return null;  
      }  
     public long getItemId(int position) {   
      return 0;  
      }  
     public View getView(int position, View convertView, ViewGroup parent) {   
      ImageView imageView = null; 

      if (convertView == null) { 
       // if it's not recycled, initialize some attributes    
       imageView = new ImageView(mContext);    
       imageView.setLayoutParams(new GridView.LayoutParams(85, 85));    
       imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);    
       imageView.setPadding(8, 8, 8, 8); 
       } else { 
       imageView = (ImageView) convertView;   
       } 
      Bitmap bmp = BitmapFactory.decodeFile(dir.getPath() + "/" + fileNames[position]); 
      imageView.setImageBitmap(bmp); 
      toast(dir.getPath() + "/" + fileNames[position]); 
      return imageView;  
     } 

     public View getView1(int arg0, View arg1, ViewGroup arg2) { 
      // TODO Auto-generated method stub 
      return null; 
     } 
    } 

    public void toast (String msg) 
    { 
     Toast.makeText (getApplicationContext(), msg, Toast.LENGTH_SHORT).show(); 
    } 
} 

오류 로그 : 당신이 게시 오류에서

08-11 23:52:38.874: ERROR/MBGlossaryManager(5395): lib_glossary.so can't be loaded<br/> 
08-11 23:52:49.710: ERROR/dalvikvm-heap(5395): 10036224-byte external allocation too large for this process.<br/> 
08-11 23:52:49.710: ERROR/(5395): VM won't let us allocate 10036224 bytes.<br/> 
08-11 23:52:49.710: ERROR/AndroidRuntime(5395): Uncaught handler: thread main exiting due to uncaught exception.<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395): java.lang.OutOfMemoryError: bitmap size exceeds VM budget.<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.graphics.BitmapFactory.nativeDecodeStream(Native Method).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:459).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:271).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:296).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at com.easyhome.GridActivity$ImageAdapter.getView(GridActivity.java:81).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.AbsListView.obtainView(AbsListView.java:1291).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.GridView.makeAndAddView(GridView.java:1218).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.GridView.makeRow(GridView.java:265).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.GridView.fillDown(GridView.java:218).<br/> 
08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.GridView.fillFromTop(GridView.java:337).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.GridView.layoutChildren(GridView.java:1112).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.AbsListView.onLayout(AbsListView.java:1130).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.View.layout(View.java:6942).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1119).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.LinearLayout.layoutVertical(LinearLayout.java:998).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.LinearLayout.onLayout(LinearLayout.java:918).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.View.layout(View.java:6942).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.FrameLayout.onLayout(FrameLayout.java:333).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.View.layout(View.java:6942).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1119).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.LinearLayout.layoutVertical(LinearLayout.java:998).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.LinearLayout.onLayout(LinearLayout.java:918).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.View.layout(View.java:6942) 
08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.widget.FrameLayout.onLayout(FrameLayout.java:333).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.View.layout(View.java:6942).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.ViewRoot.performTraversals(ViewRoot.java:1007).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.view.ViewRoot.handleMessage(ViewRoot.java:1656).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.os.Handler.dispatchMessage(Handler.java:99).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.os.Looper.loop(Looper.java:136).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at android.app.ActivityThread.main(ActivityThread.java:4425).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at java.lang.reflect.Method.invokeNative(Native Method).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at java.lang.reflect.Method.invoke(Method.java:521).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:850).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:608).<br/> 

08-11 23:52:49.764: ERROR/AndroidRuntime(5395):  at dalvik.system.NativeStart.main(Native Method).<br/> 
+0

logcat에 어떤 오류가 표시됩니까? – Collecter

+0

어떻게 logcat을 사용하여 오류 메시지를 볼 수 있습니까? –

+0

사실, logcat은 내게 어떤 메시지도주지 않습니다. –

답변

0

java.lang.OutOfMemoryError: bitmap size exceeds VM budget.

는 이미지 파일이 너무 큰 것 같다. 얼마만큼의 메모리가 필요합니까? 이미지 최적화를 시도하십시오.

2

그리드보기에서는 sdcard의 이미지를 표시하기 위해 원본 해상도 이미지가 필요하지 않습니다. BitmapFactory.Options.inSampleSize를 사용하면 항상 작은 크기의 이미지를 얻을 수 있습니다. 이렇게해도 메모리 예외가 발생하지는 않습니다.

BitmapFactory.Options opt = new BitmapFactory.Options(); 
opt.inSampleSize = 5; //any value greater than 1 
Bitmap bmp = BitmapFactory.decodeFile(dir.getPath() + "/" + fileNames[position],opt); 
관련 문제