package com.javaeye.android.my;
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 GraphicesActivity 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,100,100,
new int[]{Color.RED,Color.GREEN,Color.BLUE,Color.YELLOW},
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.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);
}
}
}
分享到:
相关推荐
在Android平台上,绘制图形是一项基本任务,而Path类则是实现复杂图形绘制的关键工具。Path类允许开发者定义一系列的几何路径,这些路径可以是直线、曲线、矩形等形状的组合,然后通过Canvas对象进行绘制。在讲解...
这个“头像上传和拍照,path画图”的示例项目旨在演示如何在应用中实现这一特性,结合拍照和自定义图形绘制,为用户提供丰富的个性化体验。下面将详细阐述相关知识点。 1. 头像上传: - 文件选择:在Android或iOS...
vb 画图 vb 画图 vb 画图 vb 画图 vb 画图 vb 画图
在windows平台下用QT实现的画图工具 可移植 在windows平台下用QT实现的画图工具 可移植 在windows平台下用QT实现的画图工具 可移植 在windows平台下用QT实现的画图工具 可移植 在windows平台下用QT实现的画图工具 可...
在本话题中,我们将重点讨论Flowable的画图工具及其与Activiti的关系。 Flowable画图工具,也称为Flowable Modeler,是Flowable框架的一部分,它允许用户通过图形化界面设计和编辑工作流模型。这个工具提供了拖放...
画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码...
"Windows老版本画图软件资源包"是一个包含了早期Windows操作系统中的内置画图应用程序的压缩文件。这个软件在Windows系统的历史中扮演了重要角色,尤其对于初学者和非专业设计师来说,它是一个简单易用的图像编辑...
【标题】"仿windows画图程序"涉及到的核心技术是使用Visual Basic(VB)来开发一个图形用户界面(GUI)应用程序,该程序具有类似Windows内置的“画图”工具的功能。在Windows操作系统中,“画图”程序是一个简单的...
在ASP.NET 2.0开发环境中,C#作为主要的编程语言,提供了丰富的功能来实现网页画图。本文将深入探讨如何利用C#在ASP.NET中进行页面画图,包括基本概念、常用技术以及实际应用示例。 1. **GDI+与绘图基础** GDI+...
在Windows操作系统中,"画图"是一款非常基础且实用的图像编辑软件,尤其在早期的Windows版本中,它被广泛用于简单的图像处理和编辑任务。随着技术的发展,微软在新版本中对画图软件进行了升级,增加了图层功能,但这...
《极致画图:一款超越Win7画图的强大工具》 在我们的日常工作中,经常会遇到需要进行简单绘图或编辑图片的情况。Windows系统自带的“画图”工具因其简洁易用的特点,一直以来都是许多用户的选择。然而,随着需求的...
VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色画图,VC颜色...
《Windows画图板:探索动态画图的魅力》 Windows画图板,作为一款简单易用的图形编辑软件,是微软操作系统内置的一个基础工具,尤其适合初学者和儿童进行简单的绘图活动。它提供了丰富的基本画图功能,让用户能够...
windows11的画图板存在bug,什么图层问题,输入文字之后会变模糊,每次输入文字的时候都需要重置字体和字体大小等等的问题,在这里给大家一个旧版本的画图板,就是windows10的画图板,windows10的画图板还是相对好用,在...
在这个场景中,"C++画图板 画图工具"是一个基于MFC实现的图形用户界面应用程序,专门用于绘画和图形编辑。 首先,我们来深入了解一下MFC。MFC库包含了类和函数,它们提供了对Windows操作系统的核心服务、窗口、控件...
在"JavaScript画图画图画图画图画图"这个主题中,我们主要关注的是使用JavaScript来实现图形绘制的功能。JavaScript提供了多种方法来创建、操作和展示图形,这包括基本的绘图API以及更高级的库,如Canvas API和SVG。...
在C#编程环境中,利用Windows Forms或WPF框架,我们可以创建具有画图功能的应用程序。本教程将深入探讨如何在C#中实现画图功能,包括基本绘图操作、图形对象以及用户交互。 首先,我们需要引入`System.Drawing`命名...
win11这个画图软件直接让人难受,搞个图层移动后下面就是透明。我就想个简单的画图,搞那么复杂干嘛,与其这样,还不如我直接去PS了。所以这个win10画图软件分享给大家。记住先卸载win11的,再看庄
Vista画图绿色版是一款专为Windows XP用户设计的应用程序,它使得在没有Vista操作系统的情况下,用户也能体验到Vista系统自带的画图工具。这个绿色版本将Vista画图的功能完整移植到了XP系统中,省去了安装VAIOXP等第...
总之,Android的画图功能强大且灵活,通过Canvas、Bitmap、Paint、Path等类的组合使用,可以创造出丰富多样的2D图形和动画效果,满足各种定制化的需求。在实际开发中,熟练掌握这些知识点能帮助开发者打造出更具吸引...