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. JS之链式运动,及任意值运动框架,包括透明度的改变

    链式运动,顾名思义,一环扣一环,即执行完一个事件后,再接着执行下一个事件,在参数上面动手脚,将下一个要执行的函数名作为一个参数,即利用到回掉函数,下面代码中出现的fn,即回掉函数, function ...

  2. createThread和_beginthreadex区别

    摘自:http://blog.csdn.net/morewindows/article/details/7421759 CreateThread()函数是Windows提供的API接口,在C/C++语 ...

  3. 经典dp 编辑距离

    给定两个字符串S和T,对于T我们可以进行三种操作 (1)在任意位置增加字符 (2)删除字符 (3)替换字符 问最少多少次能把T变成S? 设f(i,j)是S的前i位和T的前j位对齐的最小花费 接下来分析 ...

  4. 虚拟主机VPS区别:DigitalOcean优惠码

    虚拟主机与VPS区别在哪?这里从几个角度解释下: 虚拟化技术 把一台独立服务器用虚拟化技术“切割”开,分配不同的硬件配置,然后分配给不同的普通用户使用,就是虚拟主机的基本思路.部分奸商为了节省成本,甚 ...

  5. NOIP2011-普及组复赛-第二题-统计单词数

    题目描述 Description 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数.  现在,请你编程实现这一功能,具体要求是:给 ...

  6. photoshop的页面制作练习1

  7. http?https?相对协议?

    1 1 1 将CDN 上所有链接的协议默认设置为“相对协议”,也就是链接以 // 开头,前面去掉了 http: 或 https: 字样, 这样做的好处是浏览器能够根据你的网站所采用的协议来自动加载 C ...

  8. hdu_5794_A Simple Chess(lucas+dp)

    题目链接:hdu_5794_A Simple Chess 题意: 给你n,m,从(1,1)到(n,m),每次只能从左上到右下走日字路线,有k(<=100)的不能走的位置,问你有多少方案 题解: ...

  9. cmstop中实例化controller_admin_content类传递$this,其构造方法中接收到的是--名为cmstop的参数--包含cmstop中所有属性

    主程序cmstop类,实例化controller_admin_content类(接收请求后拼接的).传递cmstop所有属性过去.controller_admin_content.构造方法中接收到名称 ...

  10. 编写程序,从vector<char>初始化string

    #include<iostream> #include<string> #include<vector> using namespace std; int main ...