如何解决imageadpter错误?

时间:2011-05-04 07:46:43

标签: java android gallery directory

嗨,现在我正在尝试在我的画廊中创建文件夹,但我的应用程序崩溃在这一行...如何解决这些错误请帮助我....

imagegrid.setAdapter(new ImAdapterh(getApplicationContext()));
System.out.println("index"+getApplicationContext());

代码:

public class ImAdapterh extends BaseAdapter{

File dir=new File(Environment.getExternalStorageDirectory(),"/Pictures/");

int count=dir.list().length; 

String[] fileNames = dir.list();

 private Context mContext;

   public ImAdapterh(Context c) {
       mContext = c;
   }

   public int getCount() {
       return count;
   }

   public Object getItem(int position) {
       return null;
   }

   public long getItemId(int position) {
       return 0;
   }

   // create a new ImageView for each item referenced by the Adapter
   public View getView(int position, View convertView, ViewGroup parent) {
       ImageView imageView = null;        


     for(String bitmapFileName : fileNames)
     {
          if (convertView == null) 
          {  // if it's not recycled, initialize some attributes
              imageView = new ImageView(mContext);
              imageView.setLayoutParams(new Gallery.LayoutParams(85, 85));
              imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
              imageView.setPadding(8, 8, 8, 8);                   

              Bitmap bmp = BitmapFactory.decodeFile(dir.getPath() + "/" +   
        bitmapFileName);
              System.out.println(dir);
              imageView.setImageBitmap(bmp);  
           }else 
           {
           imageView = (ImageView) convertView;            

           }
       } 
       return imageView;
       }
    }}

logcat错误:

05-03 22:37:50.134: DEBUG/AndroidRuntime(1328): Shutting down VM
05-03 22:37:50.134: WARN/dalvikvm(1328): threadid=1: thread exiting with uncaught 
exception (group=0x4001d800)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328): FATAL EXCEPTION: main
05-03 22:37:50.184: ERROR/AndroidRuntime(1328): java.lang.RuntimeException: Unable to 
start activity 
 ComponentInfo{ImageViewExample.ImageViewExample/ImageViewExample
.ImageViewExample.ImageViewExample}: java.lang.NullPointerException
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at  
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
android.app.ActivityThread.access$2300(ActivityThread.java:125)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
android.os.Handler.dispatchMessage(Handler.java:99)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
android.os.Looper.loop(Looper.java:123)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
android.app.ActivityThread.main(ActivityThread.java:4627)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
java.lang.reflect.Method.invokeNative(Native Method)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at   
java.lang.reflect.Method.invoke(Method.java:521)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
dalvik.system.NativeStart.main(Native Method)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328): Caused by: 
java.lang.NullPointerException
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
ImageViewExample.ImageViewExample.ImageViewExample$ImAdapterh.<init>  
(ImageViewExample.java:72)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at    
ImageViewExample.ImageViewExample.ImageViewExample
.init_phone_image_grid(ImageViewExample.java:49)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at   
ImageViewExample.ImageViewExample.ImageViewExample
.onCreate(ImageViewExample.java:36)
05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at   
android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
    05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     at 
 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
 05-03 22:37:50.184: ERROR/AndroidRuntime(1328):     ... 11 more

1 个答案:

答案 0 :(得分:1)

我不认为我真的理解这个问题......但是,你得到一个空指针异常。

这对我来说不对:

public Object getItem(int position) 
{        
  return null;    
} 

然而,它与this example相同,所以我确定它没问题。

如果您的应用程序在此行崩溃(您已说过):

imagegrid.setAdapter(new ImAdapterh(getApplicationContext()));

然后似乎是,该行上必须有空值,或者其中一个调用的副作用导致异常。

所以,显而易见的可能性:

  1. 此时imagegrid是否为空?如果是这样,在其上调用方法将导致null异常。您可能已在某处创建并初始化它,但您不包含该代码。
  2. getApplicationContext是否返回非null?它是在ImAdapterh的构造函数中分配的,但没有被构造函数使用,但是值得检查。
  3. 您的ImAdapterh包含以下行:

    File dir=new File(Environment.getExternalStorageDirectory(),"/Pictures/");
    int count=dir.list().length;
    String[] fileNames = dir.list();  
    

    这似乎很容易让我感到错误,虽然它可能是文体......我会尝试将其更改为:

    File dir;
    int count;
    String[] fileNames;
    

    然后在类的构造函数中构造对象。如果其中一行引起问题(并允许您在构造函数代码上设置断点),这也可以为您提供更好的堆栈跟踪。

    我还会在getView方法的开头设置一个断点,看看是否因为imagegrid设置了适配器而调用了它。