Я использую этот метод, и он работает каждый раз, если файл в формате xml, и терпит неудачу, если он в любом другом формате.
Bitmap bm = BitmapFactory.decodeResource(getResources(), drawableId);
ниже будет работать, так как он имеет xml,
Bitmap bm = BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher_background);
в папке с возможностью рисования есть изображение test.PNG, и оно не будет работать:
Bitmap bm = BitmapFactory.decodeResource(getResources(), R.drawable.test);
чего не хватает в этом коде для поддержки декодирования другого формата?
Я специально не масштабирую растровое изображение на тестовом изображении, и оно тоже маленькое.
Вот логарифм:
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.ram.myapplication, PID: 12759
java.lang.NullPointerException
at android.graphics.Canvas.throwIfCannotDraw(Canvas.java:1083)
at android.graphics.Canvas.drawBitmap(Canvas.java:1139)
at com.example.ram.myapplication.MySurfaceView.drawSomething(MySurfaceView.java:96)
at com.example.ram.myapplication.MySurfaceView$1.surfaceCreated(MySurfaceView.java:69)
at android.view.SurfaceView.updateWindow(SurfaceView.java:608)
at android.view.SurfaceView.access$000(SurfaceView.java:96)
at android.view.SurfaceView$3.onPreDraw(SurfaceView.java:185)
at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:847)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1994)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1063)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5993)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761)
at android.view.Choreographer.doCallbacks(Choreographer.java:574)
at android.view.Choreographer.doFrame(Choreographer.java:544)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5584)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1268)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1084)
at dalvik.system.NativeStart.main(Native Method)
Большое спасибо за ваше время.
Изменить: мне пришлось изменить каталог. Где-то нашел - нельзя использовать папку Drawable. Поэтому пришлось использовать сырую папку.
MySurfaceView
. - person ADM   schedule 03.01.2018