2011-10-01 4 views
0

왜 Drawable에서 NPE를 얻을 수 있습니까? pic = (Drawable) i.getDrawable(); ?????? 매트릭스를 통해 imageswitcher에서 이미지 뷰의 XY에 맞도록 스케일을 설정하기 위해 드로어 블의 높이와 너비를 가져 오려고합니다 (멀티 터치를 활성화하는 매트릭스 사용).왜 NPE입니까?

public View makeView() { 

     ImageView i = new ImageView(this); 
     Drawable pic = (Drawable) i.getDrawable(); 
     float displayHeight = i.getHeight(); 
     float imageHeight = pic.getIntrinsicHeight(); 
     float displayWidth = i.getWidth(); 
      float imageWidth = pic.getIntrinsicWidth(); 
     float scaleX = (float) displayWidth/(float) imageWidth; 
     float scaleY = (float) displayHeight/(float) imageHeight; 
     matrix.setScale(scaleX, scaleY); 
     i.setBackgroundColor(0xFF000000); 
     i.setLayoutParams(new ImageSwitcher.LayoutParams(LayoutParams.MATCH_PARENT, 
       LayoutParams.MATCH_PARENT)); 
     i.setImageMatrix(matrix); 
     i.setScaleType(ScaleType.MATRIX); 

오류 로그 :

E/AndroidRuntime(22016): FATAL EXCEPTION: main 
E/AndroidRuntime(22016): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.ben.test/com.ben.test.ImageSwitch1}: java.lang.NullPointerException 
E/AndroidRuntime(22016): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
E/AndroidRuntime(22016): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
E/AndroidRuntime(22016): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
E /AndroidRuntime(22016): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
E/AndroidRuntime(22016): at android.os.Handler.dispatchMessage(Handler.java:99) 
E/AndroidRuntime(22016): at android.os.Looper.loop(Looper.java:123) 
E/AndroidRuntime(22016): at android.app.ActivityThread.main(ActivityThread.java:3683) 
E/AndroidRuntime(22016): at java.lang.reflect.Method.invokeNative(Native Method) 
E/AndroidRuntime(22016): at java.lang.reflect.Method.invoke(Method.java:507) 
E/AndroidRuntime(22016): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841) 
E/AndroidRuntime(22016): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599) 
E/AndroidRuntime(22016): at dalvik.system.NativeStart.main(Native Method) 
E /AndroidRuntime(22016): Caused by: java.lang.NullPointerException 
E/AndroidRuntime(22016): at com.ben.test.ImageSwitch1.makeView(ImageSwitch1.java:185) 
E/AndroidRuntime(22016): at android.widget.ViewSwitcher.obtainView(ViewSwitcher.java:80) 
E/AndroidRuntime(22016): at android.widget.ViewSwitcher.setFactory(ViewSwitcher.java:99) 
E/AndroidRuntime(22016): at com.ben.test.ImageSwitch1.onCreate(ImageSwitch1.java:100) 
E/AndroidRuntime(22016): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
E/AndroidRuntime(22016): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
E/AndroidRuntime(22016): ... 11 more 
W/ActivityManager(1106): Force finishing activity com.ben.test/.ImageSwitch1 
W/ActivityManager(1106): Force finishing activity com.ben.test/.LP 
+6

은 NPE의 스택 추적을 제시해주십시오 (이 null을 반환한다는 사실에 의해 입증 된 바와 같이)

근본적인 문제

새로 만든 이미지 뷰 아직 그와 관련된 당김이없는 것입니다. –

+0

나는 그것이 당신이 찾고있는 것이라고 생각하는데 다른 데이터를 원한다면 알려주십시오 ... – benbeel

+0

코드의 185 번째 줄을 알려 주시면 도움이 될 것입니다 ... –

답변

1

getDrawable()는 거의 확실 null 값을 반환합니다. 그 자체로는 문제가되지 않지만 Null 값을 Drawable에 캐스팅하려고하면 NPE를 얻습니다.

+0

감사합니다. @JesusFreke, 제 생각에 당신은 절대적으로 맞습니다. 나는 imageswitcher를 사용하고 있으며 이미지 리소스는 imageAdapter의 코드 (mSwitcher.setImageResource (mImages [position])와 비슷하다. 그래서 왜 makeView가 아직 연결되어 있지 않은 drawable인가? – benbeel