SkBitmap  bmp;
bmp.setConfig(SkBitmap::kARGB_8888_Config, rect.Width(), rect.Height());
bmp.allocPixels();
SkCanvas canvas(bmp);
SkPaint paint;
SkRect rect;
SkPaint::Style oldStyle; //画矩形
// rect.setXYWH(100, 100, 200, 200);
// paint.setColor(SK_ColorRED);
// paint.setStrokeWidth(1);
// oldStyle = paint.getStyle();
// //kStroke_Style,画边框
// //kFill_Style,填充
// paint.setStyle(SkPaint::kStroke_Style);
// canvas.drawRect(rect, paint);
// paint.setStyle(oldStyle); //画线
// paint.setStrokeWidth(1);
// paint.setColor(SK_ColorBLACK);
// paint.setAntiAlias(true);//抗锯齿
// canvas.drawLine(0, 0, 300, 100, paint); //画贝塞尔曲线
// SkPath path;
// SkPoint pt[4];
//
// pt[0].set(100, 100);
// pt[1].set(200, 80);
// pt[2].set(300, 80);
// pt[3].set(400, 100);
// path.moveTo(pt[0]);
// //二次贝塞尔曲线
// //path.quadTo(pt1, pt2);
// //三次贝塞尔曲线
// path.cubicTo(pt[1], pt[2], pt[3]);
// paint.setAntiAlias(true);//抗锯齿
// paint.setStyle(SkPaint::kStroke_Style);
// paint.setStrokeWidth(1);
// paint.setColor(SK_ColorBLACK);
// canvas.drawPath(path, paint);
// //贝塞尔点
// paint.setColor(SK_ColorRED);
// canvas.drawCircle(pt[0].x(), pt[0].y(), 4, paint);
// canvas.drawCircle(pt[1].x(), pt[1].y(), 4, paint);
// canvas.drawCircle(pt[2].x(), pt[2].y(), 4, paint);
// canvas.drawCircle(pt[3].x(), pt[3].y(), 4, paint); //画椭圆
// rect.setXYWH(100, 100, 300, 200);
// paint.setColor(SK_ColorBLUE);
// paint.setStyle(SkPaint::kFill_Style);//填充
// paint.setAntiAlias(true);//抗锯齿
// canvas.drawOval(rect, paint); //渐变
// SkPoint pts[2] = {100, 0, 400, 0};
// SkColor colors[3] = {SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE};//渐变颜色
// SkScalar pos[3] = {0, 0.2, 1.0};//颜色过渡率
// int count = SK_ARRAY_COUNT(colors);
// SkShader* shader = SkGradientShader::CreateLinear(pts,
// colors,
// pos,
// count,
// SkShader::kMirror_TileMode);
// //shader对象控制权交给paint
// paint.setShader(shader);
// shader->unref();
// rect.setXYWH(100, 100, 300, 200);
// canvas.drawRect(rect, paint);
// paint.setShader(NULL);//释放shader //画点集合
// SkPoint pts[] = {{100, 100},
// {200, 100},
// {200, 200},
// {100, 200}};
// int count = SK_ARRAY_COUNT(pts);
// SkCanvas::PointMode mode = SkCanvas::kPolygon_PointMode;
// paint.setColor(SK_ColorBLUE);
// paint.setStrokeWidth(1);
// canvas.drawPoints(mode,
// count,
// pts,
// paint); //画路径
// SkPath path;
//
// path.addRect(0, 0, 100, 100);
// path.addCircle(100, 100, 50);
// paint.setColor(SK_ColorRED);
// //kStroke_Style,路径轮廓,
// //kFill_Style,填充模式
// paint.setStyle(SkPaint::kStroke_Style);
// canvas.drawPath(path, paint); //画文字
// wstring text = L"hello Skia!";
// paint.setColor(SK_ColorRED);
// paint.setTextEncoding(SkPaint::kUTF16_TextEncoding);//UNICODE编码
// paint.setTextSize(30);
// paint.setAntiAlias(true);//抗锯齿
// paint.setStyle(SkPaint::kFill_Style);
// canvas.drawText(text.c_str(), text.length() * 2, 100, 100, paint);//(100, 100)左下点坐标
// //得到绘画文字的高度和宽度
// SkScalar width = paint.measureText(text.c_str(), text.length() * 2);
// SkScalar height = paint.getTextSize();
// rect.setXYWH(100, 100, width, height);
// paint.setStyle(SkPaint::kStroke_Style);
// canvas.drawRect(rect, paint);
// paint.setStyle(SkPaint::kFill_Style); //文字旋转
// wstring text = L"123456";
// SkPath path;
// SkPoint pts[2];
// pts[0].set(200, 200);
// pts[1].set(200, 100);
// path.addPoly(pts, 2, false);
// paint.setStyle(SkPaint::kStroke_Style);//轮廓
// paint.setColor(SK_ColorRED);
// canvas.drawPath(path, paint);//画路径
// paint.setAntiAlias(true);//平滑
// paint.setStyle(SkPaint::kFill_Style);//填充
// paint.setTextSize(20);
// paint.setTextEncoding(SkPaint::kUTF16_TextEncoding);//UNICODE编码
// paint.setColor(SK_ColorBLACK);
// canvas.drawTextOnPath(text.c_str(), text.size() * 2, path, NULL, paint);//画竖直文字 //路径
// SkPath path[2];
// SkPoint pts[4];
// SkMatrix mx;
//
// pts[0].set(50, 50);
// pts[1].set(75, 25);
// pts[2].set(125, 25);
// pts[3].set(150, 50);
// path[0].addPoly(pts, 4, true);
// mx.reset();
// mx.setTranslateX(100);//X坐标平移100
// path[1].addPoly(pts, 4, true);
// path[0].addPath(path[1], mx);//添加新路径
// canvas.drawPath(path[0], paint); //设置剪切区
// SkPath pa[2];
// SkPoint pts[4];
//
// pts[0].set(100, 100);
// pts[1].set(200, 100);
// pts[2].set(200, 200);
// pts[3].set(100, 200);
// pa[0].addPoly(pts, 4, true);
// pts[0].set(150, 125);
// pts[1].set(250, 125);
// pts[2].set(250, 175);
// pts[3].set(150, 175);
// pa[1].addPoly(pts, 4, true);
//
// paint.setColor(SK_ColorBLUE);
// canvas.save(SkCanvas::kClip_SaveFlag);//保存剪切区
// canvas.clipPath(pa[0], SkRegion::kReplace_Op);
// canvas.clipPath(pa[1], SkRegion::kXOR_Op);
// canvas.drawPath(pa[0], paint);
// canvas.drawPath(pa[1], paint);
// canvas.restore();//还原剪切区 //绕中心点旋转矩形
// SkPoint ptCenter; // paint.setAntiAlias(true);
// paint.setStyle(SkPaint::kStroke_Style);
// paint.setColor(SK_ColorBLACK);
// paint.setStrokeWidth(1.0f); // rect.setXYWH(50, 50, 100, 50);
// ptCenter.fX = rect.centerX();
// ptCenter.fY = rect.centerY(); // canvas.save(SkCanvas::kMatrix_SaveFlag);
// canvas.translate(ptCenter.fX, ptCenter.fY);//平移坐标系到矩形中心点
// canvas.rotate(30.0f);
// rect.offset(-ptCenter.fX, -ptCenter.fY);//将矩形中心点平移到原点(0,0)
// canvas.drawRect(rect, paint);//绘画旋转后的矩形
// canvas.restore(); // rect.offset(ptCenter.fX, ptCenter.fY);
// paint.setColor(SK_ColorRED);
// canvas.drawRect(rect, paint);

skia入门的更多相关文章

  1. dotnet 控制台 使用 Microsoft.Maui.Graphics 配合 Skia 进行绘图入门

    本文将告诉大家如何在 dotnet 的控制台模式下,采用 MAUI 自绘库 Microsoft.Maui.Graphics 进行绘图,设置 Microsoft.Maui.Graphics 底层调用 M ...

  2. Flutter基础系列之入门(一)

    1.Flutter是什么? 官方介绍:Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面. Flutter可以与现有的代码一起工作.在全世界,Flutter ...

  3. Flutter入门教程(一)Flutter简介

    这是Flutter系列第一篇文章,后续会持续更新Flutter相关知识,本篇就主要对于Flutter技术做一个简单的入门介绍 一.Flutter简介 Flutter是谷歌的移动UI框架,可以快速在iO ...

  4. 写给前端的 react-native 入门指南

    前言 本文主要介绍 react-native(下称 RN) 的入门, 和前端的异同点 文章不涉及功能的具体实现 选择优势 我们先说说, 为什么很多人会选择使用 RN .他对应的特性和普通 Web 的区 ...

  5. Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求

    上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...

  6. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  7. Oracle分析函数入门

    一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...

  8. Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数

    上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...

  9. Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数

    上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...

随机推荐

  1. hdu_5821_Ball(贪心)

    题目链接:hdu_5821_Ball 题意: 给你序列A和序列B,依次给你m个区间,每次你可以交换区间内的任意数,问最后能不能将A变成B 题解: 比赛当时没想到,智商被压制 1001: 假设有4个红球 ...

  2. WebSocket的原理,以及和Http的关系

    一.WebSocket是HTML5中的协议,支持持久连接:而Http协议不支持持久连接. 首先HTMl5指的是一系列新的API,或者说新规范,新技术.WebSocket是HTML5中新协议.新API. ...

  3. AVL树 高度平衡的二叉查找树

    1.What is AVL tree? AVL tree 是一种特殊的二叉查找树,,首先我们要在树中引入平衡因子balance,表示结点右子树的高度减去左子树的高度差(右-左),对于一棵AVL树要么它 ...

  4. 安装asterisk

    在centos6.5上: yum -y install lynx mysql-server mysql mysql-devel php php-mysql php-mbstring tftp-serv ...

  5. Python 的方法重载

    为防止两个模块互相导入的问题,Python默认所有的模块都只导入一次,如果需要重新导入模块,Python2 7可以直接用reload(),Python3可以用下 为防止两个模块互相导入的问题,Pyth ...

  6. 转 shell awk 使用详解

    awk简介 awk: 中文意思是报告生成器 能够根据我们输入的信息,将信息格式化以后显示,将定义好的信息以比较美观(直观)的方式显示出来出现比较早,继而出现了new awk(nawk)在windows ...

  7. 怎么查看window7的.net framework的版本

    第一步.打开控制面板,在大图标查看方式下,点击“程序和功能” 第二步.在程序和功能界面,点击左侧“打开或关闭Windows功能” 第三步.在打开或关闭Windows功能界面,通过拖动滚动条的方式,找到 ...

  8. 重复T次的LIS的dp Codeforces Round #323 (Div. 2) D

    http://codeforces.com/contest/583/problem/D 原题:You are given an array of positive integers a1, a2, . ...

  9. JSP之JavaBean

    一.定义 1 JavaBean是一个遵循特定写法的Java类,它通常具有如下特点: 这个Java类必须具有一个无参的构造函数 属性必须私有化. 私有化的属性必须通过public类型的方法暴露给其它程序 ...

  10. CodeForces 753C Interactive Bulls and Cows (Hard)

    题意:... 析:随机判断就即可,每次把不正确的删除,经过几次后就基本剩不下了. 代码如下: #pragma comment(linker, "/STACK:1024000000,10240 ...