import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.LinearGradient;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.RectF;
import android.graphics.Shader;
import android.graphics.Bitmap.Config;
import android.graphics.Paint.Align;
import android.graphics.PorterDuff.Mode;
import android.graphics.drawable.Drawable; public class DrawUtil
{
/**
* 画出一个这样一个图形:中间带标题文字的半圆,半圆能够设置阴影和顶部的矩形投影
*
* @param text
* 标题文字 (此处设置为两个字的居中效果)
* @param radio
* 半圆的半径
* @param shadowWidth
* 阴影的宽度
* @param isWithRectf
* 是否有矩形投影
* @param rectfColor
* 矩形投影的颜色
* @param paint
* 画笔对象
* @return
*/
public static Bitmap drawHalfCircleWithText(String text, int radio,
int shadowWidth, boolean isWithRectf, int rectfColor, Paint paint)
{
Bitmap bitmap = Bitmap.createBitmap(radio * 2,
radio * 2 + shadowWidth, Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
// 画一个带圆心的扇形,此处为半圆
canvas.drawArc(new RectF(0, 0, radio * 2, radio * 2), 360, 180, true,
paint); // 是否须要在半圆顶部画出一个矩形投影 if (isWithRectf)
{
paint = reset(paint);
paint.setColor(rectfColor);
Bitmap bmp = drawRectf(radio * 2, radio/8, paint); paint = reset(paint);
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_ATOP));//去掉矩形投影和半圆不相交的部分
canvas.drawBitmap(bmp, 0, radio, paint); }else
{
LinearGradient lg=new LinearGradient(0,0,0,radio/8,0x44000000,0x00000000,Shader.TileMode.MIRROR);
paint = reset(paint);
paint.setShader(lg);
Bitmap bmp = drawRectf(radio * 2, radio/8, paint); paint = reset(paint);
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_ATOP));//去掉矩形投影和半圆不相交的部分
canvas.drawBitmap(bmp, 0, radio, paint);
} //在半圆上面画上文字
paint = reset(paint);
paint.setColor(Color.WHITE);
paint.setTextSize(radio * 5 / 12);
paint.setTextAlign(Align.CENTER);
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_OVER));
canvas.drawText(text, radio, radio * 5 / 3, paint);
bitmap = Bitmap.createBitmap(bitmap, 0, radio, radio * 2, radio
+ shadowWidth);
return bitmap;
} /**
* 依据宽度画出一条指定三角形数量的锯齿
*
* @param screenWidth
* 宽度
* @param triangleHeight
* 锯齿的高度
* @param triangleNum
* 三角形的数量
* @param isDown
* 三角形顶点的朝向,true表示向下。false表示向上
* @param paint
* 画笔对象
* @return 返回bitmap对象
*/
public static Bitmap drawtriangle(float screenWidth, float triangleHeight,
int triangleNum, boolean isDown,Paint paint)
{
float triangleWidth = screenWidth / triangleNum;
Bitmap bitmap = Bitmap.createBitmap((int) screenWidth,
(int) triangleHeight, Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
Path path = new Path();
if(isDown)
{
path.moveTo(0, 0);
for (int i = 0; i < triangleNum * 2; i++)
{
if (i % 2 == 0)
{
path.lineTo((triangleWidth / 2) * (i + 1), triangleHeight);
} else if (i % 2 == 1)
{
path.lineTo((triangleWidth / 2) * (i + 1), 0);
}
}
}else
{
path.moveTo(0, triangleHeight);
for(int i = 0; i < triangleNum * 2; i++)
{
if(i % 2 == 0)
{
path.lineTo((triangleWidth / 2) * (i + 1), 0);
} else if(i % 2 == 1)
{
path.lineTo((triangleWidth / 2) * (i + 1), triangleHeight);
}
}
}
path.close();
canvas.drawPath(path, paint);
return bitmap;
} /**
* 画出一条带有指定半圆数量的花边
* @param width 花边的长度
* @param num 半圆的数量
* @param paint 画笔对象
* @return
*/
public static Bitmap drawMultHalfCircle(int width, int num,Paint paint)
{
int radio = (width/num)/2;
Bitmap bitmap = Bitmap.createBitmap(width,
radio, Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
for(int i = 0; i < num; i++)
{
canvas.drawBitmap(drawHalfCircle(radio, paint), radio*2*i, 0, paint);
}
return bitmap;
} /**
* 画一个矩形
* @param width
* @param height
* @param color
* @param paint
* @return
*/
public static Bitmap drawRectf(float width, float height, Paint paint)
{
Bitmap bitmap = Bitmap.createBitmap((int)width, (int)height, Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
canvas.drawRect(0, 0, width, height, paint);
return bitmap;
} /**
* 画出一个半圆
*
* @param radio
* 半径
* @param paint
* @return
*/
public static Bitmap drawHalfCircle(int radio, Paint paint)
{
Bitmap bitmap = Bitmap.createBitmap((int) (radio * 2),
(int) (radio * 2), Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
canvas.drawArc(new RectF(0, 0, radio * 2, radio * 2), 360, 180, true,
paint);
bitmap = Bitmap.createBitmap(bitmap, 0, radio, radio * 2, radio);
return bitmap;
} /**
* 依据图片的短边裁剪成圆形并在周围画上一定宽度的白边
* @param bitmap
* @param ringWidth
* @param radio
* @param paint
* @return
*/
public static Bitmap drawBitmapWithRing(Bitmap bitmap,int ringWidth,Paint paint)
{
Bitmap roundBitmap = toRoundBitmap(bitmap);
int radio = roundBitmap.getWidth() / 2;
Bitmap _bitmap = Bitmap.createBitmap((radio+ringWidth) * 2,
(radio+ringWidth) * 2, Config.ARGB_8888);
Canvas canvas = new Canvas(_bitmap);
canvas.drawCircle((radio+ringWidth), (radio+ringWidth), (radio+ringWidth), paint); paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_OVER));
canvas.drawBitmap(roundBitmap, ringWidth, ringWidth, paint);
return _bitmap;
} /**
* 将图像裁剪成圆形
*
* @param bitmap
* @return
*/
public static Bitmap toRoundBitmap(Bitmap bitmap)
{
if(bitmap == null)
{
return null;
} int width = bitmap.getWidth();
int height = bitmap.getHeight();
float roundPx;
float left, top, right, bottom, dst_left, dst_top, dst_right, dst_bottom;
if (width <= height)
{
roundPx = width / 2;
top = 0;
bottom = width;
left = 0;
right = width;
height = width;
dst_left = 0;
dst_top = 0;
dst_right = width;
dst_bottom = width;
} else
{
roundPx = height / 2;
float clip = (width - height) / 2;
left = clip;
right = width - clip;
top = 0;
bottom = height;
width = height;
dst_left = 0;
dst_top = 0;
dst_right = height;
dst_bottom = height;
} Bitmap output = Bitmap.createBitmap(width, height, Config.ARGB_8888);
Canvas canvas = new Canvas(output); final int color = 0xff424242;
final Paint paint = new Paint();
final Rect src = new Rect((int) left, (int) top, (int) right,
(int) bottom);
final Rect dst = new Rect((int) dst_left, (int) dst_top,
(int) dst_right, (int) dst_bottom);
final RectF rectF = new RectF(dst); paint.setAntiAlias(true); canvas.drawARGB(0, 0, 0, 0);
paint.setColor(color);
canvas.drawRoundRect(rectF, roundPx, roundPx, paint); paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, src, dst, paint);
return output;
} public static Bitmap darwShadow(Bitmap bitmap,int color,int padding)
{
int width = bitmap.getWidth() + padding;
int height = bitmap.getHeight() + padding;
Bitmap output = Bitmap.createBitmap(width, height, Config.ARGB_8888);
Canvas canvas = new Canvas(output);
Paint paint = new Paint();
paint = reset(paint);
paint.setColor(color);
canvas.drawBitmap(bitmap, padding/2, padding/2, null);
canvas.drawRoundRect(new RectF(0, 0, width, height),padding/2,padding/2,paint);
return output;
} private static Paint reset(Paint paint)
{
paint.reset();
paint.setAntiAlias(true);
paint.setStyle(Paint.Style.FILL);
return paint;
}
}

Android中特殊图形的生成样例的更多相关文章

  1. Android清理设备内存具体完整演示样例(二)

    版权声明: https://blog.csdn.net/lfdfhl/article/details/27672913 MainActivity例如以下: package cc.c; import j ...

  2. Android平台调用Web Service:演示样例

    近期在学习Android,随着移动设备的流行,当软件走上商业化的道路,为了争夺市场,肯定须要支持Android的,所以開始接触了Android,只是仅仅了解皮毛就好,由于我们要做管理者嘛,懂点Andr ...

  3. Android SqlDelight具体解释和Demo样例

    一.简单介绍 SQLDelight 和 SqlBrite 是 Square 公司推出的一个 Android 平台数据库解决方式. 在了解这个两个东西前,必须先得有Andorid的Sqlite的知识(S ...

  4. 【Scala篇】--Scala中Trait、模式匹配、样例类、Actor模型

    一.前述 Scala Trait(特征) 相当于 Java 的接口,实际上它比接口还功能强大. 模式匹配机制相当于java中的switch-case. 使用了case关键字的类定义就是样例类(case ...

  5. Android设计模式之中的一个个样例让你彻底明确装饰者模式(Decorator Pattern)

    导读 这篇文章中我不会使用概念性文字来说明装饰者模式.由于通常概念性的问题都非常抽象.非常难懂.使得读者非常难明确究竟为什么要使用这样的设计模式.我们设计模式的诞生,肯定是前辈们在设计程序的时候遇到了 ...

  6. Android 中 shape 图形的使用

    转载于:http://kofi1122.blog.51cto.com/2815761/521605 Android中常常使用shape来定义控件的一些显示属性,今天看了一些shape的使用,对shap ...

  7. Android清理设备内存具体完整演示样例(一)

    MainActivity例如以下: package come.on; import android.app.Activity; import android.content.Context; impo ...

  8. 10个开发中常用的PHP代码样例

    一.黑名单过滤 function is_spam($text, $file, $split = ':', $regex = false){ $handle = fopen($file, 'rb'); ...

  9. 《Android源代码设计模式解析》读书笔记——Android中你应该知道的设计模式

    断断续续的,<Android源代码设计模式解析>也看了一遍.书中提到了非常多的设计模式.可是有部分在开发中见到的几率非常小,所以掌握不了也没有太大影响. 我认为这本书的最大价值有两点,一个 ...

随机推荐

  1. Java 自定义日志写入

    /** * 将信息写入到日志 * @param content * @return * @throws IOException */ public static boolean writeLog(St ...

  2. anglehack参赛总结

    自已不足的方面: 自已和伙伴是带着idea去的,但是没有带有很大的热情激励和吸引在场的hacker加入团队,一定要找最优秀的人加入团队,事实上我是有这方面识人认人的能力的,24h,5-6个人的优秀团队 ...

  3. Server-side Sessions with Redis | Flask (A Python Microframework)

    Server-side Sessions with Redis | Flask (A Python Microframework) Server-side Sessions with Redis By ...

  4. 俄罗斯方块SDK版

    前言 本来可以从俄罗斯方块控制台版改一版, 将UI接口换掉, 变成SDK版. 正好放假了, 有时间. 就用了一个星期来重头做一个新版, 享受一下静下心来, 有条不紊干活的感觉^_^ 这个工程用来验证S ...

  5. 基于visual Studio2013解决C语言竞赛题之1065二维排序

        题目 解决代码及点评 /* 功能:二维数组排序.设有4×5的数组M,通过排序使 M[1][1]≤M[1][2]≤...≤M[1][5]≤M[2][1]≤M[2][2]≤...≤ ...

  6. poj 2299 逆序数

    http://poj.org/problem?id=2299 坑:答案是long long 输出……!!!!! 题意是:求一个数组进行冒泡排序交换的次数 题解:求逆序数 题解Ⅰ: 归并排序求逆序数 归 ...

  7. 杭电OJ_DIY_YTW2_1001 A Mathematical Curiosity

    Problem Description Given two integers n and m, count the number of pairs of integers (a,b) such tha ...

  8. C++学习之路—继承与派生(四)拓展与总结

    (根据<C++程序设计>(谭浩强)整理,整理者:华科小涛,@http://www.cnblogs.com/hust-ghtao转载请注明) 1    拓展部分 本节主要由两部分内容组成,分 ...

  9. Google Ads Encryption Key

    aes | floyd's Google Ads Encryption Key

  10. Linux通配符摘要

    参考<鸟哥linux私房菜> * - 通配符,代表随机字符(0对于许多) ? - 通配符,它代表一个字符 # - 凝视 / - 跳转符号,将特殊字符或通配符还原成一般符号 | - 分隔两个 ...