AGG第三十八课 一些不常用的坐标转换管道

简介:

5 agg::conv_smooth_poly1_curve

圆滑过渡多边形各顶点(贝塞尔)

头文件:#include"agg/include/agg_conv_smooth_poly1.h"

基本定义:

   template<class VertexSource>

   struct conv_smooth_poly1_curve :

publicconv_curve<conv_smooth_poly1<VertexSource> >

构造参数为VertexSourcesmooth_value属性决定圆滑度(默认为1

简单应用例子:

   agg::path_storage ps;

   ps.move_to(100,200);

   ps.line_to(300,500);

   ps.line_to(400,400);

   ps.close_polygon(true);

   agg::conv_smooth_poly1_curve<agg::path_storage> cspc(ps);

ras.add_path(cspc);

6  agg::conv_bspline

圆滑过渡多义线各顶点(贝塞尔)

这里需要声明多义线的概念:

就是通常说的多段线,它是线段的组合体而已。比如说“Z”字形的线条,如果是用线段画的话,那么就有三条线段。实际上多边形是多义线的一种,一种多义线。

头文件:#include"agg/include/agg_conv_bspline.h"

基本定义:

   template<class VertexSource>

structconv_bspline : public conv_adaptor_vcgen<VertexSource, vcgen_bspline>

构造函数为VertexSourceinterpolation_step属性决定步长

例子:

    agg::path_storage ps;

    ps.move_to(100,200);

    ps.line_to(300,500);

    ps.line_to(400,400);

    //ps.close_polygon(true);//一个非常奇怪的图案

    agg::conv_stroke<agg::path_storage>stroke(ps);

   agg::conv_bspline<agg::conv_stroke<agg::path_storage> >cbsp(stroke);

    ras.add_path(cbsp);

6 agg::conv_marker建立标记

详细参考箭头

7 agg::conv_curve

可识别VertexSource中的曲线信息 构造参数为VertexSource,conv_smooth_poly1_curve就是基于它实现的。例程里的顶点没有曲线的信息,在文字输出时会用到她的。



     本文转自fengyuzaitu 51CTO博客,原文链接:http://blog.51cto.com/fengyuzaitu/1965792,如需转载请自行联系原作者




相关文章
|
7月前
|
算法 vr&ar 图形学
☆打卡算法☆LeetCode 171. Excel 表列序号 算法解析
☆打卡算法☆LeetCode 171. Excel 表列序号 算法解析
|
7月前
|
SQL 算法 vr&ar
☆打卡算法☆LeetCode 175. 组合两个表 算法解析
☆打卡算法☆LeetCode 175. 组合两个表 算法解析
|
算法
【算法挨揍日记】day12——153. 寻找旋转排序数组中的最小值、LCR 173. 点名
已知一个长度为 n 的数组,预先按照升序排列,经由 1 到 n 次 旋转 后,得到输入数组。例如,原数组 nums = [0,1,2,4,5,6,7] 在变化后可能得到:
116 1
|
Java Shell
Codeforces Round #746 (Div. 2) D - Hemose in ICPC ?(交互 二分 欧拉序)
Codeforces Round #746 (Div. 2) D - Hemose in ICPC ?(交互 二分 欧拉序)
158 0
☆打卡算法☆LeetCode 97、交错字符串 算法解析
“给定三个字符串s1、s2、s3,验证s3是否是s1和s2的交错组成的。”