How to use canvas in your android apps - Part 2


SDK Version: 
M3

In the second part of this tutorial series, I will show you what you can do with canvas and paint.


If you complete the first part, your onDraw method in Panel class is similar as this:

  1.         @Override
  2.         public void onDraw(Canvas canvas) {
  3.                
  4.                 Paint paint = new Paint();
  5.                
  6.  
  7.                 Bitmap kangoo = BitmapFactory.decodeResource(getResources(),
  8.                                 R.drawable.kangoo);
  9.                 canvas.drawColor(Color.BLACK);
  10.                 canvas.drawBitmap(kangoo, 130, 10, null);
  11.                
  12.         }
  13.          

We will use the the Paint type object this time. You can use it to draw lines, circles and text on your canvas. For example this two lines will draw a red circle for you.

  1. paint.setColor(Color.RED);
  2. canvas.drawCircle(20, 50, 25, paint);

A blue circle with antialiasing turned on:

  1.         paint.setAntiAlias(true);
  2.         paint.setColor(Color.BLUE);
  3.         canvas.drawCircle(60, 50, 25, paint);

Now we will create some triangles. Create a Path object to store our triangle's segments. Use .offset to draw in many locations.

  1.                         paint.setStyle(Paint.Style.FILL_AND_STROKE);
  2.                         paint.setStrokeWidth(2);
  3.                         paint.setColor(Color.GREEN);
  4.                         Path path = new Path();
  5.                         path.moveTo(4, -10);
  6.                         path.lineTo(20, 0);
  7.                         path.lineTo(-9, 0);
  8.                         path.close();
  9.                         path.offset(60, 40);
  10.                         canvas.drawPath(path, paint);
  11.                         path.offset(90, 100);
  12.                         canvas.drawPath(path, paint);
  13.                         path.offset(80, 150);
  14.                         canvas.drawPath(path, paint);

Now draw a text using FILL style:

  1.                         paint.setStyle(Paint.Style.FILL);
  2.                         paint.setAntiAlias(true);
  3.                         paint.setTextSize(20);
  4.                         canvas.drawText("Hello Android! Fill...", 50, 230,
  5.  
  6. paint);

You can rotate the text, and you can draw it where you want:

  1.         int x = 75;
  2.         int y = 185;
  3.         paint.setColor(Color.GRAY);
  4.         paint.setTextSize(25);
  5.         String rotatedtext = "Rotated helloandroid :)";

Draw bounding rect before rotating text:

  1. Rect rect = new Rect();
  2. paint.getTextBounds(rotatedtext, 0, rotatedtext.length(), rect);
  3. canvas.translate(x, y);
  4. paint.setStyle(Paint.Style.FILL);
  5.  
  6. canvas.drawText("Rotated helloandroid :)", 0, 0, paint);
  7. paint.setStyle(Paint.Style.STROKE);
  8. canvas.drawRect(rect, paint);
  9.  
  10. canvas.translate(-x, -y);
  11.  
  12.                        
  13. paint.setColor(Color.RED);
  14. canvas.rotate(-45, x + rect.exactCenterX(),y + rect.exactCenterY());
  15. paint.setStyle(Paint.Style.FILL);
  16. canvas.drawText(rotatedtext, x, y, paint);
  17.                        

Now draw a draw a thick dashed line in angle:

  1. DashPathEffect dashPath = new DashPathEffect(new float[]{10,40}, 1);
  2. paint.setPathEffect(dashPath);
  3. paint.setStrokeWidth(8);
  4. canvas.drawLine(0, 60 , 320, 300, paint);

Comments

Issues are very interesting and very useful, thank you for the information provided. Hoteles Granada

Very nice presentation of the post, I was suggested this blog by means of my bro. Thanks ea sports cricket 2011 game

This tutorial was very useful when managing my android mobile, and I also had find ways to reduce my mobile phone bill and other expenses.

I think we need to bring more ideas for this purpose. Involvement of young people can be handy in this regard. I am happy to find a good post here. Bankruptcy lawyers

Thank you - the site very very nice

المجتمع المصري هو مجتمع يحب الترفية حيث ان سكان مصر تصل الى تسعون مليون فرد ولذلك نحن نقدم خدمة دردشة مصرية لكل اهل مصر ام الدنيا , وتعتبر مصر متقدمة فى هذا العالم من حيث النمو فى مجالات التكنولوجيا و الكمبيوتر بنسبة كبيرة جدا لذلك نفضل دخول شات مصري اكبر تجمع بنات و شباب فى شات الحب و اجمل بنات فى دردشة دردشة الحب , اضافة الى ذلك حيث يوجد دردشة قوية تضم جميع محافظات مصر هي شات مصرية الكتابية نتمني لكم قضاء وقت ممكن فى شات الاصدقاء و احلي دردشة التعارف الذي يوجد به بنات رومانسية فى دردشة بنات مصر المصرية


شات الحب - دردشة مصرية - شات - شات مصري - شات حب - دردشة - دردشة كتابية - دردشة الحب - شات حبنا - شات حبي - شات مصرية - دردشة حب - شات بنات - دردشة مصر - دردشة بنات مصر - شات بنات مصر - شات صوتي - chat love - دردشة ياحبي - شات بنات لبنان - الحب - شات كتابي - منتدي ياحبي - شات مصر - دردشة حبنا - العاب تلبيس البنات - دردشة بنات - شات ياحبي - Chat - شات لبناني - شات كلامنجي - دردشة كلامنجي - شبكة - تصميم مواقع - تصميم - شات الاسكندرية - دردشة لبنانية - دردشة بنات لبنان - بنات لبنان - موقع شات - سعودي كول - شات سعودي كول - شات بنت مصر - شات سكس

I have been looking for this sort of tutorial for a long time, so Thanks.

This is a fantastic website and I can not recommend you guys enough. Full of useful resource and great layout very easy on the eyes. Please do keep up this great work. western sky financial

Thank you! it was a wonderful chance to visit this kind of site and I am happy to know. thank you so much for giving us a chance to have this opportunity! Jane Taylor // Photo Book

It's so tough to encounter right information on the blog. I really loved reading this post. It has strengthen my faith more. You all do such a great job at such concepts. ..can't tell you how much I for one appreciate all you do. Tim Barnes // metal gazebo

Hey your site is really great I came across while in search for brand info on bing and it has lots of related information on it. Will be sure to come back again and bookmark. Keep up the great work! Paul Graeme // T-shirt Druck

A very good and informative article indeed . It helps me a lot to enhance my knowledge, I really like the way the writer presented his views. windows hosting

Perhaps this is a bit off topic but in any case I have been surfing about your blog and it looks really neat. impassioned about your writing. I am creating a new blog and hard-pressed to make it appear great and supply excellent articles. I have discovered a lot on your site and I look forward to additional updates and will be back. Pat Baker // Limpieza Madrid

An impressive share I just given this onto a colleague who was doing a little analysis on this. And he in fact bought me breakfast because I found it for him.. smile. So let me reword that: Thnx for the treat! But yeah Thnkx... Gary Peters // Nardini

Nice information many thanks to the author. It is incomprehensible to me now but in general the usefulness and significance is overwhelming
klebeband bedrucken

The author has written an excellent article. You made your point and not much to discuss. It's like this universal truth that you can not argue with the truth is not universal everything has its exception. Thanks for this information.
Contract cleaning in London

This is my first time i visit here. I found so many interesting stuff in your blog especially its discussion. From the tons of comments on your articles I guess I am not the only one having all the enjoyment here! keep up the good work. Adam Cooper // HID Ballast Xenon Bulbs

Thanks John I thoroughly enjoyed reading your article. I really appreciate your wonderful knowledge and the time you put into educating the rest of us.
Peter, from Ebooks

That was good... waiting for the next update. Btw: when will be the next update? John Paul // lottozahlen

Thanks so much for sharing your wealth of information
BenTen Oyunları - Zeka Oyunları - Komik Oyunlar - Oyunlar- Araba Yarışı Oyunları

These kind of post are always inspiring and I prefer to read quality content so I happy to find many good point here in the post writing is simply great thank you for the post
Terapia tartamudez

Thanks for posting this article. I am definitely tired of struggling to find relevant and intelligent commentary on this subject. Everyone nowadays seem to go to extremes to either drive home their viewpoint or suggest that everybody else in the globe is wrong. Thanks for your concise and relevant insight. Adam Fairfax // Pool Plaster Supplies

A very good and informative article indeed . It helps me a lot to enhance my knowledge, I really like the way the writer presented his views. motorcycle auctions

I believe that youtube is a great tool for anyone interested in watching or uploading videos. I have been using the site for years now and still think it is doing a good job! John Simmons // Diseño web

Favorite post having such an fantastic and useful informative content.describing good blogging concepts as well as basics that are very much useful in skilled content writing as well. Alex Martinson // Pest Control

A very good and informative article indeed . It helps me a lot to enhance my knowledge, I really like the way the writer presented his views. xperia play accessories

I believe that youtube is a great tool for anyone interested in watching or uploading videos. I have been using the site for years now and still think it is doing a good job! Fran Hebdon // flyer design

A very informative article and lots of really honest and forthright comments made! This certainly got me thinking a lot about this issue so thanks a lot for posting! Flint Patrick // Last Minute Angebote

Thanks for such a great post i will be listing this in my monthly newsletter. Many thanks and i hope to help spread the word
Drinks Veniding machines

I dont think Ive seen all the angles of this subject the way youve pointed them out. Youre a true star a rock star man. Youve got so much to say and know so much about the subject that I think you should just teach a class about it John Ford // SEO

Please keep on posting such quality articles as this is a rare thing to find these days. I am always searching online for articles that can help me. Looking forward to another great blog. Good luck to the author! all the best! Pete Sunders // Datenrettung Festplatte

The author has written an excellent article. You made your point and not much to discuss. It's like this universal truth that you can not argue with the truth is not universal everything has its exception. Thanks for this information. Dean thomas // moviles dual sim

It's not tough to spot the best Android app developers. All you need to do is simply look at their applications.

best android apps

best iphone apps

Excellent read, I just passed this onto a colleague who was doing a little research on that. And he actually bought me lunch because I found it for him smile So let me rephrase that:

http://www.foronovia.com
http://bienvenidomisterchip.blogspot.com
http://www.vestidosytrajes.com
http://www.nuvitex.com
http://www.cochesdenovios.com
http://www.mueblemexicano.com
http://www.lasnaranjas.es
http://www.spainbridal.com

Finally an issue that I am passionate about. I have looked for information of this caliber for the last several hours. Your site is greatly appreciated. Fred Bacon // Acupuntura Valencia

I concur with your conclusions and will eagerly look forward to your future updates. The usefulness and significance is overwhelming and has been invaluable to me! Patrick Johns // Inmobiliaria en las palmas

Another very solid tutorial. Thank you. Not something I can use right now but I bookmarked for the future. Vernon Gray // family office

Really appreciate this wonderful post that you have provided for us.Great site and a great topic as well i really get amazed to read this. breastfeeding dress

Hrmm that was weird my comment got eaten. Anyway I wanted to say that it's nice to know that someone else also mentioned this as I had trouble finding the same info elsewhere. This was the first place that told me the answer. Thanks. Sue Ripley // Heat Recovery

Took me time to read all the comments but I really enjoyed the article. It proved to be Very helpful to me and I am sure to all the commenter here! It's always nice when you can not only be informed but also entertained! Tim Partz // vestidos novia

To tell you the teuth I was passing around and come across your site. It is wonderful. I mean as a content and design. I added you to my list and decided to spent the rest of the weekend browsing. Well done!
Messe Hotel München

Die hausrat abschliessen.
Einen Hausrat testen.
Wie ein Haus versichert wird.

This is a fantastic website and I can not recommend you guys enough. Full of useful resource and great layout very easy on the eyes. Please do keep up this great work. Medical Assistant

I'm extremely impressed with your writing skills as well as with the layout on your weblog. Is this a paid theme or did you modify it yourself? Anyway keep up the nice quality writing it’s rare to see a nice blog like this one these days.. Max O'Neil // Toner

I was very pleased to find this site. I wanted to thank you for this unique read. I definitely savoured all bits and pieces of it including all the comments and I have added you to my bookmark list to check out new articles you post. Don Joy // poloshirts

Thanks for this guestbook mate. Well, this is my first visit to your site! But I admire the precious time and effort you put into it. keep it up! wholesale imitation jewelry