package com.mdrawable;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.graphics.Path;
import android.graphics.Shader;
import android.graphics.LinearGradient;
//主程序中继承自Android.view.View的 MyView类,重写 MyView的onDraw()方法,
//一开始就会运行绘制的工作,在onDraw()中以Paint将几何图形绘制在Canvas上,
//以 paint.setColor() 改变图形颜色、以 paint.setStyle()的设置来控制画出的的
//图形是空心还是实心。程序的最后一段,就是直接在Canvas写上文字,随着Paint对
//象里的属性设置,也会有不同的外观模式。
public class mdrawable extends Activity {
/** Called when the activity is first created. */
@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);
/*画一个空心椭圆形*/
canvas.drawOval(new RectF(10,220,70,250), 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的颜色*/
paint.setColor(Color.BLUE);
/*设置paint 的style为 FILL:实心*/
paint.setStyle(Paint.Style.FILL);
/*画一个实心圆*/
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,0,480,
new int[]{Color.argb(127,0, 0, 255),Color.rgb(0, 0, 0)},
null,Shader.TileMode.REPEAT);
//Shader.TileMode三种模式
//REPEAT:沿着渐变方向循环重复
//CLAMP:如果在预先定义的范围外画的话,就重复边界的颜色
//MIRROR:与REPEAT一样都是循环重复,但这个会对称重复
paint.setShader(mShader);//用Shader中定义定义的颜色来话
/*画一个渐变色圆*/
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 paint11=new Paint();
/*去锯齿*/
paint11.setAntiAlias(true);
/*设置paint的颜色*/
paint11.setColor(Color.RED);
/*设置paint的 style 为STROKE:空心*/
paint11.setStyle(Paint.Style.STROKE);
/*设置paint的外框宽度*/
paint11.setStrokeWidth(3);
Path path6=new Path();
path6.moveTo(170, 410);
path6.lineTo(230,410);
path6.lineTo(215,350);
path6.lineTo(185, 350);
path6.close();
canvas.drawPath(path6, paint11);
/*写字*/
paint.setTextSize(24);
canvas.drawText("圆形", 240, 50, paint);
canvas.drawText("正方形", 240, 120, paint);
canvas.drawText("长方形", 240, 190, paint);
canvas.drawText("椭圆形", 240, 250, paint);
canvas.drawText("三角形", 240, 320, paint);
canvas.drawText("梯形", 240, 390, paint);
}
}
}
分享到:
相关推荐
绘制渐变图形 绘制渐变图形 绘制渐变图形 绘制渐变图形 绘制渐变图形 绘制渐变图形
这是一套绿色渐变图形背景PPT模板,共11张。第一PPT模板网提供颜色渐变设计幻灯片模板免费下载; 关键词:绿色渐变叠加花卉幻灯片背景图片,蓝色PowerPoint底图,彩色微立体PPT图表,.PPTX格式;
填充矩形 随机画矩形 鼠标绘图 色彩变换矩阵 全局变形图形 漂亮的C#登录窗口(动画效果) 路径 另存为 绘制颜色渐变图形 绘制线条 绘制椭圆 绘制扇形 绘制抛物线 绘制矩形 绘制弧线 绘制多边形和折线 ...
透明度渐变三角形拼图背景,细线条标题文本框,渐变梯形重叠突出标题过渡页,简约个人总结,个人年中总结报告ppt模板,51PPT模板网 原创。
23.如何绘制渐变色图形?(Visual C++编程 源代码)23.如何绘制渐变色图形?(Visual C++编程 源代码)23.如何绘制渐变色图形?(Visual C++编程 源代码)23.如何绘制渐变色图形?(Visual C++编程 源代码)23.如何...
上课做的作业,各种艺术字代码,还有方程图形
这是一套绿色渐变图形背景PPT模板,共11张。第一PPT模板网提供颜色渐变设计幻灯片模板免费下载; 关键词:绿色渐变叠加花卉幻灯片背景图片,蓝色PowerPoint底图,彩色微立体PPT图表,.PPTX格式;
VC小程序,绘制渐变色图形,在窗体的空白处绘制渐变色图形,通过参阅源代码你将了解到它的实现原理,并熟悉如何设置两点间的颜色,如何改变颜色域值,渐变交接处的长短等。本程序对于VC新手来说是相当有用的。
渐变几何图形创意封面,渐变几何图形创意过渡页,渐变几何图形汇报图表,适合商务工作汇报、工作总结的精美渐变几何图形创意ppt模板。
比例图表创意设计目录页,亮蓝渐变超大数字序号几何圆渐变过渡页,亮蓝渐变半透明精美几何图形图表,适合工作总结、工作汇报等场景应用的亮蓝渐变几何图形线条精美大气科技感ppt模板。
逐点绘制渐变三角形,不用调用库函数的方法,实现点画三角形。
针对蜡染图形创新, 提出一种基于增量式迭代变换法的图形渐变方法, 即在不受特征点集对应的约束下, 实现两个平面图形之间自然、平滑渐变。该方法采用迭代渐变的思想, 对图形进行矢量预处理, 并分别在源矢量图形和目标...
CSS3实现图形颜色渐变 CSS3实现图形颜色渐变效果网页特效.zip
中华神捕包含功能如下: 1、可以轻松抓取整个桌面、选定对象、选定矩形区域、选定多边形区域。...5、支持多种作图方式,可自定义任意渐变图形作图方案、50余种图案填充作图方案、任意改变线型、线宽。
提出了一种新的算法, 该算法根据图形渐变序列中出现的局部自交点, 先判断出这些点的位置并计算出自交区域所占整个图形面积的比例, 根据设定的阈值, 采用合理的微调整算法, 在尽可能保持源图形形态的基础上, 将自交点...
描述由一个图形变化为另一个图形过程中的各个中间图形,称为渐变图形。可以利用插值算法求得各个渐变图形。 设在源图形和目标图形上各取M个对应坐标点,并分别保存到数组中,源图形用数组SX[M]和SY[M]保存M个坐标点...
这是一款HTML5 SVG图形变化制作炫酷渐变动画特效。该特效开始时使用多层SVG图形来制作一些渐变图案。当用户点击菜单时,相应颜色的渐变图案会放大为全屏,效果非常炫酷。
超级屏幕抓图工具、超级作图工具、超级图片浏览工具... 5、支持多种作图方式,可自定义任意渐变图形作图方案、50余种图案填充作图方案、任意改变线型、线宽。 6、超级Office插件功能。 7、超级图片浏览功能。
vb Gdi+利用多颜色梯度线性渐变画刷填充图形
渐变几何图形创意商务工作汇报PPT模板.pptx