歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Android中繪制圓角矩形圖片及任意形狀圖片

Android中繪制圓角矩形圖片及任意形狀圖片

日期:2017/3/1 10:08:25   编辑:Linux編程

圓角矩形圖片在蘋果的產品中很流行,相比於普通的矩形,很多人都喜歡圓角矩形的圖片,因為它避開了直角的生硬,帶來更好的用戶體驗,下面是幾個設計的例子:

下面在Android中實現將普通的矩形圖片繪制成圓角矩形。首先看最終效果:

代碼清單:

  1. package com.example.phototest;
  2. import android.os.Bundle;
  3. import android.app.Activity;
  4. import android.graphics.Bitmap;
  5. import android.graphics.BitmapFactory;
  6. import android.graphics.Canvas;
  7. import android.graphics.Color;
  8. import android.graphics.Paint;
  9. import android.graphics.Path;
  10. import android.graphics.PorterDuffXfermode;
  11. import android.graphics.PorterDuff;
  12. import android.graphics.RectF;
  13. import android.graphics.drawable.BitmapDrawable;
  14. import android.graphics.drawable.Drawable;
  15. import android.view.Menu;
  16. import android.widget.ImageView;
  17. public class MainActivity extends Activity {
  18. private ImageView myImageView;
  19. @Override
  20. public void onCreate(Bundle savedInstanceState) {
  21. super.onCreate(savedInstanceState);
  22. setContentView(R.layout.activity_main);
  23. myImageView=(ImageView)findViewById(R.id.imageView1);
  24. Bitmap photo = BitmapFactory.decodeResource(getResources(), R.drawable.photo1);
  25. myImageView.setImageBitmap(createFramedPhoto(500,400,photo,20));
  26. //myImageView.setImageBitmap(createStarPhoto(500,400,photo));
  27. }
  28. @Override
  29. public boolean onCreateOptionsMenu(Menu menu) {
  30. getMenuInflater().inflate(R.menu.activity_main, menu);
  31. return true;
  32. }
  33. private Bitmap createFramedPhoto(int x, int y, Bitmap image, float outerRadiusRat) {
  34. //根據源文件新建一個darwable對象
  35. Drawable imageDrawable = new BitmapDrawable(image);
  36. // 新建一個新的輸出圖片
  37. Bitmap output = Bitmap.createBitmap(x, y, Bitmap.Config.ARGB_8888);
  38. Canvas canvas = new Canvas(output);
  39. // 新建一個矩形
  40. RectF outerRect = new RectF(0, 0, x, y);
  41. // 產生一個紅色的圓角矩形
  42. Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
  43. paint.setColor(Color.RED);
  44. canvas.drawRoundRect(outerRect, outerRadiusRat, outerRadiusRat, paint);
  45. // 將源圖片繪制到這個圓角矩形上
  46. //詳解見http://lipeng88213.iteye.com/blog/1189452
  47. paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
  48. imageDrawable.setBounds(0, 0, x, y);
  49. canvas.saveLayer(outerRect, paint, Canvas.ALL_SAVE_FLAG);
  50. imageDrawable.draw(canvas);
  51. canvas.restore();
  52. return output;
  53. }
  54. }
Copyright © Linux教程網 All Rights Reserved