iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android canvas画图操作之切割画布实现方法(clipRect)
  • 236
分享到

Android canvas画图操作之切割画布实现方法(clipRect)

方法canvasAndroid 2022-06-06 07:06:36 236人浏览 薄情痞子
摘要

本文实例讲述了Android canvas画图操作之切割画布实现方法。分享给大家供大家参考,具体如下: android切割画布的历程不算很难,可是理解起来也比较麻烦,这里写一下

本文实例讲述了Android canvas画图操作之切割画布实现方法。分享给大家供大家参考,具体如下:

android切割画布的历程不算很难,可是理解起来也比较麻烦,这里写一下我的理解 但是不一定正确:


canvas.clipRect(30, 30, 70, 70, Region.Op.XOR);

最后一个参数有多个选择分别是:

//DIFFERENCE是第一次不同于第二次的部分显示出来
//REPLACE是显示第二次的
//REVERSE_DIFFERENCE 是第二次不同于第一次的部分显示
//INTERSECT交集显示
//UNION全部显示
//XOR补集 就是全集的减去交集生育部分显示


import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.Region;
import android.util.AttributeSet;
import android.view.View;
public class sBook extends View{
  Context mContext;
  Paint mPaint;
  Path mPath;
  public sBook(Context context) {
    super(context);
    init();
  }
  public sBook(Context context, AttributeSet attrs) {
    super(context, attrs);
    init();
  }
  public sBook(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
    init();
  }
  private void init(){
    mPaint = new Paint();
    mPaint.setAntiAlias(true);
    mPaint.setStrokeWidth(6);
    mPaint.setTextSize(16);
    mPaint.setTextAlign(Paint.Align.RIGHT);
    mPath = new Path();
  }
  protected void onDraw(Canvas canvas){
    canvas.drawColor(Color.GRAY);
    canvas.save();
    canvas.translate(10, 10);
    drawScene(canvas);
    canvas.restore();
    canvas.save();
    canvas.translate(160, 10);
    canvas.clipRect(10, 10, 90, 90);
    canvas.clipRect(30, 30, 70, 70, Region.Op.XOR);
    drawScene(canvas);
    canvas.restore();
    canvas.save();
    canvas.translate(10, 160);
    mPath.reset();
//    canvas.clipPath(mPath); // makes the clip empty
//    mPath.addCircle(50, 50, 50, Path.Direction.CCW);
    mPath.cubicTo(0, 0, 100, 0, 100, 100);
    mPath.cubicTo(100, 100, 0, 100, 0, 0);
    canvas.clipPath(mPath, Region.Op.REPLACE);
    drawScene(canvas);
    canvas.restore();
    canvas.save();
    canvas.translate(160, 160);
    canvas.clipRect(0, 0, 60, 60);
    canvas.clipRect(40, 40, 100, 100, Region.Op.UNION);
    drawScene(canvas);
    canvas.restore();
    canvas.save();
    canvas.translate(10, 310);
    canvas.clipRect(0, 0, 60, 60);
    canvas.clipRect(40, 40, 100, 100, Region.Op.XOR);
    drawScene(canvas);
    canvas.restore();
    canvas.save();
    canvas.translate(160, 310);
    canvas.clipRect(0, 0, 60, 60);
    canvas.clipRect(40, 40, 100, 100, Region.Op.REVERSE_DIFFERENCE);
    drawScene(canvas);
    canvas.restore();
  }
  private void drawScene(Canvas canvas) {
    canvas.clipRect(0, 0, 100, 100);
    canvas.drawColor(Color.WHITE);
    mPaint.setColor(Color.RED);
    canvas.drawLine(0, 0, 100, 100, mPaint);
    mPaint.setColor(Color.GREEN);
    canvas.drawCircle(30, 70, 30, mPaint);
    mPaint.setColor(Color.BLUE);
    canvas.drawText("Clipping", 100, 30, mPaint);
  }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:Android开发之图形图像与动画(一)Paint和Canvas类学习Android中区别Drawable Bitmap Canvas PaintAndroid使用Canvas绘制圆形进度条效果Android中Canvas的常用方法总结Android编程开发之在Canvas中利用Path绘制基本图形(圆形,矩形,椭圆,三角形等)Android编程之canvas绘制各种图形(点,直线,弧,圆,椭圆,文字,矩形,多边形,曲线,圆角矩形)Android中使用Canvas绘制南丁格尔玫瑰图(Nightingale rose diagram)Android 游戏开发之Canvas画布的介绍及方法Android编程实现canvas绘制饼状统计图功能示例【自动适应条目数量与大小】Android中Paint类和Canvas类的方法汇总


--结束END--

本文标题: Android canvas画图操作之切割画布实现方法(clipRect)

本文链接: https://www.lsjlt.com/news/23539.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android开发中实现home图标动画切换效果的方法
    本篇文章为大家展示了Android开发中实现home图标动画切换效果的方法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。如图所示:实现这个效果仅需几步:首先,该页面的布局是一个DrawerLayou...
    99+
    2023-05-31
    android roi home
  • C++实现WPF动画的具体操作方法
    本篇文章为大家展示了C++实现WPF动画的具体操作方法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。C++编程语言的应方式非常广泛,可以帮助我们轻松的实现许多功能需求。很多人都习惯使用Blend来帮...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作