`
闫老三
  • 浏览: 102738 次
社区版块
存档分类
最新评论

Android Path的使用

 
阅读更多
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);     
         }   
    }   
}

 原文地址:http://ipjmc.iteye.com/blog/1290170

本文地址:http://bajiewuneng.iteye.com/blog/1919484

分享到:
评论

相关推荐

    android path 动画效果 (很酷)

    标题中的"android path 动画效果 (很酷)"指的就是使用Android的动画系统来实现路径动画,使得UI元素能够沿着预定义的路径移动,产生流畅且酷炫的视觉效果。以下将详细介绍这一技术。 首先,Path Animation是Android...

    Android中Path的使用

    这篇博客深入探讨了如何在Android中有效地使用`Path`,并可能涉及了一些源码解析和实用工具的讨论。我们将详细地分析`Path`类的使用方法和相关知识点。 1. **Path的基本概念** - `Path`是Android图形系统的一部分...

    Android Path轨迹动画事列

    在本项目中,我们将深入探讨如何实现这样的动画效果,以及在Android中使用Path和Animation的相关知识。 首先,Path对象在Android图形系统中用于定义二维路径,可以包含直线、曲线等各种形状。在动画中,Path常用于...

    Android Path 解析 绘制图形

    在Android开发中,`Path`类是用于创建和操作路径的重要工具。它允许开发者定义复杂的几何形状,并在屏幕上绘制它们。本篇文章将深入探讨`Path`类的基本概念、使用方法以及如何结合`Canvas`进行图形绘制,从而实现...

    Android path 菜单效果 Satellite Menu

    "Android Path 菜单效果 Satellite Menu"是一个实现炫酷旋转菜单的项目,它利用Path2.0技术为用户提供了一种新颖的操作方式。这种菜单在用户点击主按钮后,会从按钮周围弹出一系列小按钮,再次点击小按钮时,所有小...

    android PATH菜单实现,简洁

    - **旋转动画**:使用Android的`RotateAnimation`类来创建旋转效果。可以设定初始角度、终止角度、旋转中心等参数,然后将其应用到菜单项上。 - **淡入淡出动画**:当菜单项出现或消失时,可以添加淡入淡出效果,...

    android path画折线

    下面将详细介绍`Path`类的使用方法,以及如何在Android中绘制折线。 首先,我们需要了解`Path`类的基本概念。`Path`对象是一个包含一系列绘制命令的序列,这些命令可以是直线、曲线或者关闭路径。在Android的`...

    android利用三角函数实现仿path菜单支持半圆和圆形及1/4圆

    1. **三角函数的应用**:在Android的Path菜单中,我们通常会用到弧度制的角度值,因为Java和Android API使用的是弧度而不是角度。正弦函数(sin)和余弦函数(cos)可以将弧度转换为x轴和y轴上的坐标,帮助我们确定...

    Android中Path类的quadTo函数

    在Android的图形系统中,`Path`类是一个非常重要的组件,它用于定义和操作复杂的几何路径,这些路径可以用于绘制或者进行图形变换。本篇文章将深入探讨`Path`类中的`quadTo()`函数,以及与`lineTo()`函数的区别。 ...

    android 仿 path 苹果 iphone

    实现这种效果,可以使用Android的触摸事件处理机制,结合自定义ViewGroup和动画库来完成。在Android中,自定义View是通过继承View或者 ViewGroup,并重写其onDraw()方法来绘制我们想要的图形。对于这个半圆形的菜单...

    android 仿Path菜单

    "android 仿Path菜单"就是一个这样的尝试,它旨在模仿流行的Path应用的菜单样式,为用户提供一种新颖且直观的操作方式。下面我们将深入探讨这个菜单的实现原理和关键知识点。 首先,Path菜单的核心在于其扇形展开的...

    Android Path 解析 绘制各种图形

    本篇文章将深入解析`Path`类的使用方法,并通过实例展示如何在Android上绘制不同的图形。 `Path`类在`android.graphics`包中,它提供了创建、组合和修改路径的功能。一个路径可以包含直线、曲线以及闭合区域。首先...

    ANDROID 仿path按钮效果(无旋转)

    "ANDROID 仿path按钮效果(无旋转)"是一个尝试模拟iOS中的Path应用风格的按钮设计,它着重于提供一个美观而简洁的交互元素,而不涉及复杂的旋转动画。在这个项目中,我们将深入探讨如何在Android中实现这样的按钮...

    android版本path2菜单实现源代码

    本篇文章将详细解析如何在Android中实现类似Path 2.0的菜单功能,通过分析提供的"TestPath"源代码,我们可以学习到一些核心技术和设计理念。 首先,让我们了解菜单的基本结构。在Android中,菜单通常分为两种类型:...

    Android Path Button效果

    在Android开发中,Path Button是一种独特且富有创意的UI组件,它允许开发者通过自定义的SVG路径来设计按钮的形状,从而实现各种独特的视觉效果。Path Button的效果通常比传统的矩形或圆形按钮更加吸引人,可以提升...

    android 仿path 下拉图片放大,放开回弹 ListView

    在Android开发中,实现"仿path下拉图片放大,放开回弹ListView"的效果,涉及到的知识点主要包括自定义View、ListView的适配器Adapter、动画处理以及手势检测。下面将详细阐述这些关键点。 首先,"仿path下拉图片...

    Android代码-原来PATH的菜单效果如此简单。布局TranslateAnimation搞定.zip

    标题“Android代码-原来PATH的菜单效果如此简单。布局TranslateAnimation搞定.zip”揭示了一个关于Android应用中的PATH菜单动画实现的关键点,即使用了`TranslateAnimation`来创建这种效果。`TranslateAnimation`是...

    高仿android path下拉刷新

    在Android开发中,"高仿android path下拉刷新"是一个常见的需求,特别是在设计现代、流畅的用户界面时。Path是一个流行的设计元素,通常用于绘制曲线或路径,而在Android应用中,"Path"可能指的是对原生Android控件...

    Android仿path社交

    【Android仿Path社交应用开发详解】 在移动互联网时代,社交应用已经成为了人们日常生活的一部分,而Path作为一个曾经备受瞩目的社交平台,以其独特的设计和用户体验赢得了众多用户的喜爱。Android平台上仿制Path...

    Path 按钮特效特逼真

    "Path按钮特效"是一种独特且吸引人的视觉效果,它通过Path类在Android图形库中实现,使得按钮的外观更加生动和逼真。本文将深入探讨如何利用Path类和相关技术来创建出这种特逼真的Path按钮特效。 Path类是Android...

Global site tag (gtag.js) - Google Analytics