2010-04-16 12 views
66

मेरे पास एक दृश्य है, मैं ऑनडा (कैनवास कैनवास) विधि में कैनवास ऑब्जेक्ट के साथ चित्रित कर रहा हूं। मेरा कोड है:एंड्रॉइड Canvas.drawText

Paint paint = new Paint(); 
paint.setColor(Color.WHITE); 
paint.setStyle(Style.FILL); 
canvas.drawPaint(paint); 

paint.setColor(android.R.color.black); 
paint.setTextSize(20); 
canvas.drawText("Some Text", 10, 25, paint); 

समस्या यह है कि पाठ पृष्ठभूमि के माध्यम से नहीं दिखाता है, मैं गलत क्या कर रहा हूं? अगर मैं canvas.drawPaint (पेंट) और paint.setColor (android.R.color.black) को हटाता हूं तो आप स्क्रीन पर टेक्स्ट देख सकते हैं .....

उत्तर

117

यह काम किया, एंड्रॉइड.आर .color.black रंग के समान नहीं है। काला। कोड को बदल दिया:

Paint paint = new Paint(); 
paint.setColor(Color.WHITE); 
paint.setStyle(Style.FILL); 
canvas.drawPaint(paint); 

paint.setColor(Color.BLACK); 
paint.setTextSize(20); 
canvas.drawText("Some Text", 10, 25, paint); 

और यह सब ठीक काम करता है !!

+32

हां। यदि आप आईडी 'R.color.black' के साथ' res/colors.xml' फ़ाइल में रंग परिभाषा का उपयोग करना चाहते हैं, तो आप केवल आईडी का उपयोग नहीं कर सकते हैं। यदि आप संसाधनों से वास्तविक रंग मान प्राप्त करना चाहते हैं, तो 'paint.setcolor (getResources()। GetColor (R.color.black)) का उपयोग करें; ' –

+0

कोई भी जानता है कि एंड्रॉइड कैनवास आकार में टेक्स्ट को कैसे आकर्षित किया जाए [RectShape] (http://stackoverflow.com/questions/25401981/how-to-display-text-in-android-canvas-shapedrawable-with-rectshape)? –

+0

और 'dp' में टेक्स्ट आकार सेट करने के लिए आप [this] (http://stackoverflow.com/questions/3061930/how-to-set-unit-for-paint-settextsize) का उपयोग कर सकते हैं –

11

यह ध्यान दिया जाना चाहिए कि documentationCanvas.drawText के बजाय Layout का उपयोग करने की अनुशंसा करता है। StaticLayout का उपयोग करने के बारे में मेरा पूरा उत्तर here है, लेकिन मैं नीचे एक सारांश प्रदान करूंगा।

String text = "This is some text."; 

TextPaint textPaint = new TextPaint(); 
textPaint.setAntiAlias(true); 
textPaint.setTextSize(16 * getResources().getDisplayMetrics().density); 
textPaint.setColor(0xFF000000); 

int width = (int) textPaint.measureText(text); 
StaticLayout staticLayout = new StaticLayout(text, textPaint, (int) width, Layout.Alignment.ALIGN_NORMAL, 1.0f, 0, false); 
staticLayout.draw(canvas); 

यहाँ एक कस्टम दृश्य के संदर्भ में एक संपूर्ण उदाहरण है:

enter image description here

public class MyView extends View { 

    String mText = "This is some text."; 
    TextPaint mTextPaint; 
    StaticLayout mStaticLayout; 

    // use this constructor if creating MyView programmatically 
    public MyView(Context context) { 
     super(context); 
     initLabelView(); 
    } 

    // this constructor is used when created from xml 
    public MyView(Context context, AttributeSet attrs) { 
     super(context, attrs); 
     initLabelView(); 
    } 

    private void initLabelView() { 
     mTextPaint = new TextPaint(); 
     mTextPaint.setAntiAlias(true); 
     mTextPaint.setTextSize(16 * getResources().getDisplayMetrics().density); 
     mTextPaint.setColor(0xFF000000); 

     // default to a single line of text 
     int width = (int) mTextPaint.measureText(mText); 
     mStaticLayout = new StaticLayout(mText, mTextPaint, (int) width, Layout.Alignment.ALIGN_NORMAL, 1.0f, 0, false); 

     // New API alternate 
     // 
     // StaticLayout.Builder builder = StaticLayout.Builder.obtain(mText, 0, mText.length(), mTextPaint, width) 
     //  .setAlignment(Layout.Alignment.ALIGN_NORMAL) 
     //  .setLineSpacing(1, 0) // multiplier, add 
     //  .setIncludePad(false); 
     // mStaticLayout = builder.build(); 
    } 

    @Override 
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
     // Tell the parent layout how big this view would like to be 
     // but still respect any requirements (measure specs) that are passed down. 

     // determine the width 
     int width; 
     int widthMode = MeasureSpec.getMode(widthMeasureSpec); 
     int widthRequirement = MeasureSpec.getSize(widthMeasureSpec); 
     if (widthMode == MeasureSpec.EXACTLY) { 
      width = widthRequirement; 
     } else { 
      width = mStaticLayout.getWidth() + getPaddingLeft() + getPaddingRight(); 
      if (widthMode == MeasureSpec.AT_MOST) { 
       if (width > widthRequirement) { 
        width = widthRequirement; 
        // too long for a single line so relayout as multiline 
        mStaticLayout = new StaticLayout(mText, mTextPaint, width, Layout.Alignment.ALIGN_NORMAL, 1.0f, 0, false); 
       } 
      } 
     } 

     // determine the height 
     int height; 
     int heightMode = MeasureSpec.getMode(heightMeasureSpec); 
     int heightRequirement = MeasureSpec.getSize(heightMeasureSpec); 
     if (heightMode == MeasureSpec.EXACTLY) { 
      height = heightRequirement; 
     } else { 
      height = mStaticLayout.getHeight() + getPaddingTop() + getPaddingBottom(); 
      if (heightMode == MeasureSpec.AT_MOST) { 
       height = Math.min(height, heightRequirement); 
      } 
     } 

     // Required call: set width and height 
     setMeasuredDimension(width, height); 
    } 

    @Override 
    protected void onDraw(Canvas canvas) { 
     super.onDraw(canvas); 
     // do as little as possible inside onDraw to improve performance 

     // draw the text on the canvas after adjusting for padding 
     canvas.save(); 
     canvas.translate(getPaddingLeft(), getPaddingTop()); 
     mStaticLayout.draw(canvas); 
     canvas.restore(); 
    } 
} 
संबंधित मुद्दे