首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Android UI】Canvas 画布 ⑦ ( Canvas 绘制显示区域 | Canvas 绘制矩形源码分析 )

; Canvas 画布中 , 有 2 套坐标系 , 分别是 : Canvas 自身坐标系 Canvas 绘图坐标系 一、Canvas 绘制显示区域 ---- Canvas 绘制时 , 并不是由 Canvas..., 是无法改变的 ; 参考 【Android UI】Canvas 画布 ⑥ ( Canvas 绘图源码分析 | ViewRootImpl#draw 方法源码 | ViewRootImpl#drawSoftware...Canvas#translate , Canvas#rotate , Canvas#scale 方法 , 可以改变 Canvas 的绘图坐标系 ; Canvas 自身坐标系 有一个很重要的作用 就是 确定画布范围..., 之后所有的绘制内容只能显示这个画布范围内的元素 , 画出边界的元素是不显示的 ; 如下图 , 蓝色矩形框是 Canvas 自身坐标系 , 红色矩形框是 Canvas 绘图坐标系 , 两个坐标系重合部分...: /** * 使用指定的绘制绘制指定的矩形。

1.4K10

Android项目实战(九):CustomShapeImageView 自定义形状的ImageView

SVG可以算是目前最最火热的图片文件格式,这里作者已经给我们写好了几个特殊的图形  如果想要自定义更多形状的话,可以学习下SVG  1、shape_5.svg 五边形 ?...3、接下来就是使用了 如果我们使用raw文件夹下的svg写的形状作为ImageView的形状 则:这里一个app:svg_raw_resource="@raw/shape_star_3" 这里就是指定图片形状为...一样使用,标签变了而已 1 <com.meg7.widget.CircleImageView 2 android:layout_width="100dp" 3 android:layout_height...源码中CustomShapeImageView.java看了下源码是默认显示圆形图片的ImageView,里面有圆形,方形,自定义形,看情况使用了,个人感觉,以上的几个使用起来就足够了。...相关知识: 自定义圆形图片

68370
您找到你想要的搜索结果了吗?
是的
没有找到

Android自定义View之绘制圆形头像

那么,如何通过自定义View的方式实现圆形头像呢,那么,本片博文会告诉你不仅仅是实现过程。一定会有意想不到的收获哦! 最终效果 国际惯例,我们先来看最终实现的效果图 ?...自定义RoundImageView继承自ImageView public class RoundImageView extends ImageView { public RoundImageView...使用自定义View无非就两种情况下,第一种就是直接在xml布局中使用,另一种就是在Activity中new出来,下面我们分别使用上述两种方式,为了便于观察我们在三个构造方法中分别加入一行打印。 ?...结论:自定义View当在xml中使用使用的是第二个构造方法,当在Activity中使用时,实例化时传入几个参数调用的就是含有几个参数的构造方法。...最终我们重新将bitmap绘制出来即可 canvas.drawBitmap(bitmap, rect, rect, paint); 绘制部分完整代码如下所示: * 获取圆形裁剪的bitmap *

1.1K10

android 自定义控件之-绘制钟表盘

引言 Android 自定义 View 应用非常广泛,最近逛 github 是偶然发现一个 Demo 感觉写的很好,我结合着这个项目的内容,给大家讲讲如何绘制时钟表盘,也算是加深下自己对自定义 View...方法,保证绘制的是圆 绘制刻度线的准备 开始绘制刻度线 大功告成 ---- 让我们先搭建这个 View 首先,我们定义一个叫做 ClockView 的自定义 View ,让它继承自 View 类。...mCirclePaint = new Paint(Paint.ANTI_ALIAS_FLAG); mCirclePaint.setColor(mDarkColor); // 官方:使用此样式绘制的几何和文本将被描边...---- 绘制刻度线的准备 开始绘制先前,我们先要准备下一些工具, 首先一个 Paint 对象是必不可少的, 然后为了方便用户使用,我们再定义一个颜色,暴露给予设置, 最后我们还需要一个 int 型的值...mCanvas.restore(); } ---- 大功告成 然我们看看效果: ---- 项目 Demo 地址:https://github.com/FishInWater-1999/android_view_user_defined_first.git

99720

Android开发笔记(一百五十三)OpenGL绘制三维图形的流程

然后还要有绘画作品的载体,比如显示生活中黑板的漆面,以及用于国画的宣纸、用于油画的油布等等,在Android系统中,这个绘画载体便是画布Canvas。...正如前面介绍的Android自定义控件那样,有了视图View、画布Canvas、画笔Paint,方能绘制炫彩多姿的各种控件。...为方便理解,接下来不妨继续套用Android二维绘图的有关概念,从Android自定义控件的主要流程得知,自定义一个二维控件,主要有以下四个步骤: 1、声明自定义控件的构造函数,可在此进行控件属性初始赋值等初始化操作...和onLayout两个函数的功能; 3、onDrawFrame顾名思义跟自定义控件的onDraw函数差不多,onDraw函数用于绘制二维图形的具体形状,而onDrawFrame函数用于绘制三维图形的具体形状...-- 注意这里要使用控件的全路径android.opengl.GLSurfaceView --> <android.opengl.GLSurfaceView android:id

1.8K20

Excel图表学习63: 使用形状填充技术绘制图片信息图表

看看下图1所示的图表,是不是非常有趣且表达得非常生动,这是使用形状填充技术来绘制的图表。 ? 图1 下面来讲解这个图表是如何绘制的。...图2所示是用于绘制图表的示例数据,左侧是原始数据,右侧红色方框内是辅助数据,其中“底层”和“顶层”的100是固定值,“中间层”的值等于“数值-底层-顶层”。 ?...图3 在Excel工作表中导入或者绘制代表底层、中间层、顶层的形状图片,如下图4所示。 ? 图4 先复制代表底层的图片,然后选择图表中的底层系列,按Ctrl+V填充图表。...图5 当我们使用形状填充图表时,Excel会自动拉伸图片,但我们需要堆积图片。选取图表系列,按Ctrl+1组合键,在“设置数据系列格式”中使“系列选项”中的间隙宽度为0,如下图6所示。 ?

1.1K10

Android-2D绘图

概述 Android使用图形处理引擎,2D部分是android SDK内部自己提供,3D部分是用Open GL ES 1.0 大部分2D使用的api都在android.graphics和android.graphics.drawable...以图形处理来说,我们最常用到的就是在一个View上画一些图片、形状或者自定义的文本内容,这里我们都是使用Canvas来实现的。...你可以获取View中的Canvas对象,绘制一些自定义形状,然后调用View. invalidate方法让View重新刷新,然后绘制一个新的形状,这样达到2D动画效果。...自定义View import android.content.Context; import android.graphics.Canvas; import android.graphics.Color...Canvas类:画布 Android系统中的绘图操作主要是在Canvas画布上进行的,在绘图时,使用的是前面设置好的Paint画笔。

5K20

Android自定义Drawable之在Drawable中部指定透明区域方法示例

一种可以在Canvas上进行绘制的抽象的概念 颜色、图片等都可以是一个Drawable Drawable可以通过XML定义,或者通过代码创建 Android中Drawable是一个抽象类,每个具体的Drawable...都是其子类 Drawable的优点 使用简单,比自定义View成本低 非图片类的Drawable所占空间小,能减小apk大小 在实际的开发工程中,不免想有一个中间是空洞的Drawable,也就是中间是透明的...canvas.drawPath(srcPath, srcPaint); //清除混合模式 srcPaint.setXfermode(null); //还原画布 canvas.restoreToCount...Override public int getOpacity() { return innerDrawable.getOpacity(); } } 光有HoleDrawable是没有意义的,写个自定义...<br/ * 当然了,形状要你自己指定,目前想不到好的思路自动处理各种形状,有的话就直接完善了 <br/ * 根据个crop_image_cover_view_hole子View的位置,确定透明区域

1.7K20

Android中的各种Drawable类详解

Drawable简介 图形图像的绘制需要在画布上进行操作和处理,但是绘制需要了解很多细节以及可能要进行一些复杂的处理,这样就会增加学习和使用的成本,因此系统提供了一个被称之为Drawable的类来进行绘制处理...你需要为位图指定绘制画布上的位置以及缩放到区域的方式: //这里的android.view.Gravity参考值。...Shape是一个抽象的形状类,您可以使用如下具体的形状类: ArcShape 弧形。构造指定开始角度和增加的角度,是顺时针方向, 这里0度是在正右边。 OvalShape 椭圆形。...相当于自定义图形。构造函数的后两个参数是缩放因子。也就是x轴缩放: bounds宽度/stdWidth, y轴缩放:bounds高度/stdHeight。也就是会对绘制的位置和长度进行放大缩小。...状态stateSet可以使用:**android.R.attr.state_XXX ** 中列出的值。

1.5K20

了解 Android 的矢量图片格式:`VectorDrawable`

然而,矢量图像是通过在抽象大小的画布上定义一系列形状来描绘图像。 为什么使用矢量图?...矢量资源有三大好处,分别是: 好用 占用资源少 动态 好用 矢量图可以优雅的调整大小;这是因为它们将图像绘制在抽象大小的画布上,你可以放大或缩小画布,然后重新绘制对应尺寸的图像。...Android 在受限制的移动设备上运行,因此支持整个 SVG 规范并不是一个现实的目标。 然而,SVG 包含一个 路径规范,它定义了如何描述和绘制形状使用此 API,您可以表达大多数矢量形状。...第二个 视口 大小定义虚拟画布,或者定义所有后续绘制命令的空间坐标。固有和视口尺寸可以不同(但应该以相同的比例)— 如果你需要,可以在 1*1 画布中定义矢量。...它们可以被命名(以供稍后参考,例如动画),但至关重要的是必须指定描述形状的 pathData 元素。这个神秘的字符串可以被认为是控制虚拟画布上的笔的一系列命令: ?

2.5K30

Carson带你学Android自定义View Canvas类使用教程

前言 自定义View是Android开发者必须了解的基础;而Canvas类的使用自定义View绘制中发挥着非常重要的作用 网上有大量关于自定义View中Canvas类的文章,但存在一些问题:内容不全...过程- 最易懂的自定义View原理系列(4) 4.2.1 绘制颜色 作用:将颜色填充整个画布,常用于绘制底色 具体使用 // 传入一个Color类的常量参数来设置画布颜色 // 绘制蓝色...); // 缩放的本质是:把形状先画到画布,然后再缩小/放大。...总结 通过阅读本文,相信你已经全面了解Canvas类的使用; Carson带你学Android自定义View文章系列: Carson带你学Android自定义View基础 Carson带你学Android...:一文梳理自定义View工作流程 Carson带你学Android自定义View Measure过程 Carson带你学Android自定义View Layout过程 Carson带你学Android

2.3K10

android使用Path绘制出多边形

在讲使用path绘制多边形时,讲下Canvas的translate(),rotate()方法的使用,本博客中会使用这方面的知识,先单独讲下,搞懂了这个,下面讲path绘制多边形就简单的多,我们知道每次我们使用...activity压入栈中,translate()是画布平移,其实每次画布还是同一个画布,通过paint绘制的图形都是在这同一个canvas上,但是绘制的内容跟你是否使用了translate()有关系,下面通过简单的...第二种: 配套使用canvas.save() canvas.restore() ;save()是绑定画布,restore()是让画布恢复到最初的状态 @Override protected void onDraw...还有一个问题就是如果所绘制的是多边形,但是好像形状不一样,怎么修改,这个时候只要旋转画布就行了,比如这张图片: ? 使用canvas.rotate(30);旋转30度后是这样的 ?...当然你要在绘制这个图形之前对画布进行旋转,不然不起作用,网上有些五角星的效果,是怎么实现的呢?比如这样的效果: ? 这是正6变形所形成的星星形状,分析如图: ?

1.3K20

Android自定义WaveProgressView实现水波纹加载需求

如何使用 1.1 在布局文件中   添加自定义控件: <cn.fanrunqi.waveprogressview.WaveProgressView android:id="@+id/waveProgressbar.../   说明,这里的android:background定义的是控件的形状,比如上面的圆形和美女,你可用shape.xml定义形状图片。...<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval" <solid android...代码实现   这里实现主要用到的知识有 自定义view、PorterDuffXfermode和二阶贝塞尔曲线,不太清楚的可以在我博客找找,都有的。      ...首先自定义WaveProgressView继承View,在构造函数中获取布局文件中设置的背景,同时设置一个画波浪的画笔和画文字的画笔。

85741

Android 自定义View小实例-实现绘制打折标签

选取自定义View的方法 我们都知道自定义View有多种方式,比如继承自View、ViewGroup或者继承自现有的View子类等,每种实现方式的不同我们所需要做的处理工作也不同,从图中可以看出包含两个...,我这里没有绘制直接为布局文件添加的shape背景。...绘制打折标签 接下来的标签就是绘制标签,在这里有两个注意的问题: (1) 绘制的方式有很多,可以绘制矩形后旋转画布或者直接用Path绘制,这里我们采用使用Path绘制 (2) 既然要绘制东西,那么就要重新...睁大眼睛可以看到文字在路径的上边,设置文字大小: paintDisText.setTextSize(35f); 同样的也是在边上,我们查看源码看一下drawTextOnPath的使用以及上边设置的两个0...我们可以设置文字值和打折数目,意义是否绘制打折,如果不绘制则不会绘制path。

86060

HenCoder Android 自定义 View 1-5: 绘制顺序

这期是 HenCoder 自定义绘制的第 1-5 期:绘制顺序 之前的内容在这里: HenCoder Android 开发进阶 自定义 View 1-1 绘制基础 HenCoder Android 开发进阶...自定义 View 1-2 Paint 详解 HenCoder Android 开发进阶 自定义 View 1-3 文字的绘制 HenCoder Android 开发进阶 自定义 View 1-4 Canvas...API 去设置(xml 布局文件的 android:background 属性以及 Java 代码的 View.setBackgroundXxx() 方法,这个每个人都用得很 6 了),而不能自定义绘制...-- 使用半透明的黑色作为前景,这是一种很常见的处理 --> <AppImageView ... android:foreground="#88000000" /> ?...总结 今天的内容就是这些:使用不同的绘制方法,以及在重写的时候把绘制代码放在 super.绘制方法() 的上面或下面不同的位置,以此来实现需要的遮盖关系。下面用一张图和一个表格总结一下: ?

77430
领券