2016-08-26 5 views
3

私はdrawableフォルダから画像付きのカスタムビューを作成しようとしています。 プログラムがフォルダから選択した画像はクライアントに依存するので、変数を使ってRファイルにアプローチする必要があります。

String uriName = ":drawable/"+thisCard.getKind()+thisCard.getNumber(); 
int idUri = getResources().getIdentifier(uriName , null , PACKAGE_NAME); 
Drawable tmp = getResources().getDrawable(idUri , getContext().getTheme()); 
cardImage.setImageDrawable(tmp); 

が、私はのはRuntimeException取得「android.content.res.Resources $ NotFoundExceptionを::リソースID番号0x0の」

を、私はそれを行うための方法は、そのようなものであることを発見した研究を行った後 私が例外を検索したとき、私が書いた段落で行ったことを私に言った答えが得られました。 私は何が間違っていますか?

また、私はデバッグのためにログコマンドを挿入したコードを追加しました。その行をデバッグすると2回表示されます。なぜ私はそれを1回だけ呼び出すと、そのメソッドが2回呼ばれた理由はありますか?

コードとスタックトレースを追加しました。

protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    testView = (CardView)findViewById(R.id.testView); 
    Card card = new Card("club" , 2); 
    testView.setCard(card); 

} 

、これはのStackTraceです::

これは、クラスの一部である(それはビューを拡張する)

public void setCard(Card card){ 
    thisCard = card; 
    isSet = true; 
    //in the Card constructor isSet is false so it does not suppose to go in the method setCardImage() yet. 
    invalidate(); 
} 

private void setCardImage(){ 

    String uriName = ":drawable/"+thisCard.getKind()+thisCard.getNumber(); 

    try { 

     cardImage = (ImageView)findViewById(R.id.cardImage); 
     int idUri = getResources().getIdentifier(uriName , null , PACKAGE_NAME); 

     Drawable tmp = getResources().getDrawable(idUri , getContext().getTheme()); 
     cardImage.setImageDrawable(tmp); 

     Log.d(TAG , "im here"); 
    }catch(NullPointerException e){ 
     e.printStackTrace(); 

    } 
} 

@Override 
protected void onDraw(Canvas canvas) { 
    super.onDraw(canvas); 
    if(isSet) { 
     setCardImage(); 
    } 
} 

これはMainActivityある

08-26 07:54:33.135 2364-2364/com.example.danac.cards E/AndroidRuntime: FATAL EXCEPTION: main 
                    Process: com.example.danac.cards, PID: 2364 
                    android.content.res.Resources$NotFoundException: Resource ID #0x0 
                     at android.content.res.Resources.getValue(Resources.java:1351) 
                     at android.content.res.Resources.getDrawable(Resources.java:804) 
                     at com.example.danac.cards.CardView.setCardImage(CardView.java:51) 
                     at com.example.danac.cards.CardView.onDraw(CardView.java:65) 
                     at android.view.View.draw(View.java:16178) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15174) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15169) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15169) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.draw(View.java:16181) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15174) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15169) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15169) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15169) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15169) 
                     at android.view.View.draw(View.java:15948) 
                     at android.view.ViewGroup.drawChild(ViewGroup.java:3609) 
                     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3399) 
                     at android.view.View.draw(View.java:16181) 
                     at com.android.internal.policy.PhoneWindow$DecorView.draw(PhoneWindow.java:2690) 
                     at android.view.View.updateDisplayListIfDirty(View.java:15174) 
                     at android.view.ThreadedRenderer.updateViewTreeDisplayList(ThreadedRenderer.java:281) 
                     at android.view.ThreadedRenderer.updateRootDisplayList(ThreadedRenderer.java:287) 
                     at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:322) 
                     at android.view.ViewRootImpl.draw(ViewRootImpl.java:2615) 
                     at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2434) 
                     at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2067) 
                     at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1107) 
                     at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6013) 
                     at android.view.Choreographer$CallbackRecord.run(Choreographer.java:858) 
                     at android.view.Choreographer.doCallbacks(Choreographer.java:670) 
                     at android.view.Choreographer.doFrame(Choreographer.java:606) 
                     at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:844) 
                     at android.os.Handler.handleCallback(Handler.java:739) 
                     at android.os.Handler.dispatchMessage(Handler.java:95) 
                     at android.os.Looper.loop(Looper.java:148) 
                     at android.app.ActivityThread.main(ActivityThread.java:5417) 
                     at java.lang.reflect.Method.invoke(Native Method) 
                     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 

ありがとう

EDIT: その特定のビューのXML:私はあなたのuriNameが間違っていると思い

 <com.example.danac.cards.CardView 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:id="@+id/testView"/> 
+0

私はあなたが持っていると思いますが、パスが正しいかどうかを確認するためにidUriを表示しようとしましたか? – Isabelle

+0

あなたは.svgドロワーブルを使用していますか? – Dev

+0

@millinet - デバッグしたときに正しいパッケージ(PACKAGE_NAME = getContext()。getPackageName(); – DanaCh

答えて

-1
String uriName = ":drawable/"+thisCard.getKind()+thisCard.getNumber(); 
int idUri = getResources().getIdentifier(uriName , null , PACKAGE_NAME); 

。あなたの描画可能な名前に:あなたはを追加しないでください

String drawableName = thisCard.getKind() + thisCard.getNumber(); 
int idDrawable = getResources().getIdentifier(drawableName, "drawable", PACKAGE_NAME); 

「:描画可能な」あなたはあなたのような描画可能なのIDを取得することができます。方法getIdentifier"drawable"を追加する必要があります。がんばろう。

+0

私はあなたが言ったことを行いました。私は、imageViewのNullPointerExceptionを書きましたが、 cardImage =(ImageView)findViewById(R.id.cardImage); さらに、2回呼び出された理由を教えていただけますか? – DanaCh

+0

イメージビューコードはありません。 –

+0

また、何度も呼ばれていますか?私は理解していません –

関連する問題