基本信息
源码名称:android 裁剪图片,多功能2D绘图 例子
源码大小:0.03M
文件格式:.rar
开发语言:Java
更新时间:2014-09-18
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):78630559
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
android 2d绘图例子
android 2d绘图例子
package irdc.ex07_02;
/* import相关class */
import android.app.Activity;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.LinearGradient;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.RectF;
import android.graphics.Shader;
import android.os.Bundle;
import android.view.View;
public class EX07_02 extends Activity
{
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
/* 设定ContentView为自定义的MyView */
MyView myView = new MyView(this);
setContentView(myView);
}
/* 自定义继承View的MyView */
private class MyView extends View
{
public MyView(Context context)
{
super(context);
}
/* 覆写onDraw() */
@Override
protected void onDraw(Canvas canvas)
{
super.onDraw(canvas);
/* 设定背景为白色 */
canvas.drawColor(Color.WHITE);
Paint paint = new Paint();
/* 去锯齿 */
paint.setAntiAlias(true);
/* 设定paint的颜色 */
paint.setColor(Color.RED);
/* 设定paint的style为STROKE:空心的 */
paint.setStyle(Paint.Style.STROKE);
/* 设定paint的外框宽度 */
paint.setStrokeWidth(3);
/* 画一个空心圆形 */
canvas.drawCircle(40,40,30, paint);
/* 画一个空心正方形 */
canvas.drawRect(10,90,70,150,paint);
/* 画一个空心长方形 */
canvas.drawRect(10,170,70,200,paint);
/* 画一个空心椭圆形 */
RectF re=new RectF(10,220,70,250);
canvas.drawOval(re, paint);
/* 画一个空心三角形 */
Path path = new Path();
path.moveTo(10,330);
path.lineTo(70,330);
path.lineTo(40,270);
path.close();
canvas.drawPath(path, paint);
/* 画一个空心梯形 */
Path path1 = new Path();
path1.moveTo(10,410);
path1.lineTo(70,410);
path1.lineTo(55,350);
path1.lineTo(25,350);
path1.close();
canvas.drawPath(path1, paint);
/* 设定paint的style为FILL:实心 */
paint.setStyle(Paint.Style.FILL);
/* 设定paint的颜色 */
paint.setColor(Color.BLUE);
/* 画一个实心圆 */
canvas.drawCircle(120, 40, 30, paint);
/* 画一个实心正方形 */
canvas.drawRect(90,90,150,150,paint);
/* 画一个实心长方形 */
canvas.drawRect(90,170,150,200,paint);
/* 画一个实心椭圆形 */
RectF re2=new RectF(90,220,150,250); canvas.drawOval(re2, paint); /* 画一个实心三角形 */ Path path2 = new Path(); path2.moveTo(90,330); path2.lineTo(150,330); path2.lineTo(120,270); path2.close(); canvas.drawPath(path2, paint); /* 画一个实心梯形 */ Path path3 = new Path(); path3.moveTo(90,410); path3.lineTo(150,410); path3.lineTo(135,350); path3.lineTo(105,350); path3.close(); canvas.drawPath(path3, paint); /* 设定渐层色 */ Shader mShader=new LinearGradient(0, 0,100,100, new int[]{Color.RED, Color.GREEN,Color.BLUE,Color.YELLOW}, null, Shader.TileMode.REPEAT); paint.setShader(mShader); /* 画一个渐层色的圆形 */ canvas.drawCircle(200,40, 30, paint); /* 画一个渐层色的正方形 */ canvas.drawRect(170,90,230,150,paint); /* 画一个渐层色的长方形 */ canvas.drawRect(170,170,230,200,paint); /* 画一个渐层色的椭圆形 */ RectF re3=new RectF(170,220,230,250); canvas.drawOval(re3, paint); /* 画一个渐层色的三角形 */ Path path4 = new Path(); path4.moveTo(170,330); path4.lineTo(230,330); path4.lineTo(200,270); path4.close(); canvas.drawPath(path4, paint); /* 画一个渐层色的梯形 */ Path path5 = new Path(); path5.moveTo(170,410); path5.lineTo(230,410); path5.lineTo(215,350); path5.lineTo(185,350); path5.close(); canvas.drawPath(path5, paint); /* 写字 */ paint.setTextSize(24); canvas.drawText(getResources().getString(R.string.str_text1), 240,50,paint); canvas.drawText(getResources().getString(R.string.str_text2), 240,120,paint); canvas.drawText(getResources().getString(R.string.str_text3), 240,190,paint); canvas.drawText(getResources().getString(R.string.str_text4), 240,250,paint); canvas.drawText(getResources().getString(R.string.str_text5), 240,320,paint); canvas.drawText(getResources().getString(R.string.str_text6), 240,390,paint); } } }