Cairo 图形指南 (3) —— Cairo 后端

Cairo 支持多种后端,本文基于几个示例讲述如何使用 Cairo 各种后端创建 PNG 图像、PDF 文件与 SVG 文件以及如何使用 Cairo 在 GTK 窗口中绘图。

1. PNG 图像

第一个示例 (example-1.c) 用于生成 PNG 图像。

#include <cairo.h>

int
main  ( int argc,  char *argv [ ] )
{
        cairo_surface_t *surface;
        cairo_t *cr;

        surface =
            cairo_image_surface_create  (CAIRO_FORMAT_ARGB32,  32048 );
        cr = cairo_create  (surface );

        cairo_set_source_rgb  (cr,  0.62700 );
        cairo_select_font_face  (cr,  "Adobe Heiti Std",
                                CAIRO_FONT_SLANT_NORMAL,
                                CAIRO_FONT_WEIGHT_NORMAL );
        cairo_set_font_size  (cr,  24.0 );

        cairo_move_to  (cr,  10.034.0 );
        cairo_show_text  (cr,  "我是中国人,我爱我的祖国。" );

        cairo_surface_write_to_png  (surface,  "image.png" );

        cairo_destroy  (cr );
        cairo_surface_destroy  (surface );

         return  0;
}

这个示例是一个很小的控制台程序,运行后可生成一份 PNG 图像文件。

 #include <cairo.h>

上述头文件声明了上面示例中调用的函数以及一些常量的定义。

 cairo_surface_t *surface;
 cairo_t *cr;

这两行代码声明了一个 Cairo 外观与一个 Cairo 环境。

 surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32,  32048 );
 cr = cairo_create (surface );

现在我们生成了 Cairo 外观与 Cairo 环境,所生成的外观是一份 320x48 px 的图像。

 cairo_set_source_rgb  (cr,  0.62700 );

设置源的颜色为 darkred,就好比是选择了暗红色的颜料。

 cairo_select_font_face (cr,  " Adobe Heiti Std ", CAIRO_FONT_SLANT_NORMAL,
      CAIRO_FONT_WEIGHT_NORMAL );
 cairo_set_font_size (cr,  24.0 );

选择字体类型并设置其尺寸。(注:可使用 "fc-list" 命令查看系统所安装字体)

 cairo_move_to (cr,  10.034.0 );
 cairo_show_text (cr,  "我是中国人,我爱我的祖国。" );

将“画笔”移动到图像区域的 (10.0, 34.0) 位置开始绘制文本。

 cairo_surface_write_to_png (surface,  "image.png" );

这个函数创建 PNG 图像。

 cairo_destroy (cr );
 cairo_surface_destroy (surface );

最后,回收所有 Cairo 环境与外观所占用的内存资源。

编译这个示例:

$ gcc -o example -1 `pkg-config --cflags --libs gtk+ -2.0` example -1.c

生成的 PNG 图像如下图所示:

2. PDF 文件

在第二个示例 (example-2.c) 中,将使用 Cairo 生成一份 PDF 文件,其内容与第一个示例所生成的图像是相同的。

#include <cairo.h>
#include <cairo-pdf.h>

int
main  ( int argc,  char *argv [ ] )
{
        cairo_surface_t *surface;
        cairo_t *cr;

        surface = cairo_pdf_surface_create  ( "pdffile.pdf"32048 );
        cr = cairo_create  (surface );

        cairo_set_source_rgb  (cr,  0.62700 );
        cairo_select_font_face  (cr,  "Adobe Heiti Std",
                                CAIRO_FONT_SLANT_NORMAL,
                                CAIRO_FONT_WEIGHT_NORMAL );
        cairo_set_font_size  (cr,  24.0 );

        cairo_move_to  (cr,  10.034.0 );
        cairo_show_text  (cr,  "我是中国人,我爱我的祖国。" );

        cairo_show_page  (cr );

        cairo_destroy  (cr );
        cairo_surface_destroy  (surface );

         return  0;
}

编译这个示例:

$ gcc -o example -2 `pkg-config --cflags --libs gtk+ -2.0` example -2.c

生成的 PDF 文件,请使用 PDF 阅读器查看,Linux 用户可使用 Evince 或 KPDF。

 surface = cairo_pdf_surface_create  ( "pdffile.pdf"32048 );

要生成 pdf 文件,必须使用 cairo_pdf_surface () 函数创建一个 pdf 外观。pdf 文件的页面大小是以排版标准中的像素点尺寸为单位控制的。

 cairo_show_page (cr );

生成的 PDF 文档在 Evince 中显示效果如下图所示:

3. SVG 文件

第三个示例演示如何使用 Cairo SVG 后端生成一份简单的 SVG (Scalble Vector Graphics) 文件。SVG 技术近几年很热门。

#include <cairo.h>
#include <cairo-svg.h>

int
main  ( int argc,  char *argv [ ] )
{
        cairo_surface_t *surface;
        cairo_t *cr;

        surface = cairo_svg_surface_create  ( "svgfile.svg"32048 );
        cr = cairo_create  (surface );

        cairo_set_source_rgb  (cr,  0.62700 );
        cairo_select_font_face  (cr,  "Adobe Heiti Std",
                                CAIRO_FONT_SLANT_NORMAL,
                                CAIRO_FONT_WEIGHT_NORMAL );
        cairo_set_font_size  (cr,  24.0 );

        cairo_move_to  (cr,  10.034.0 );
        cairo_show_text  (cr,  "我是中国人,我爱我的祖国。" );

        cairo_destroy  (cr );
        cairo_surface_destroy  (surface );

         return  0;
}

编译这个示例:

$ gcc -o example -3 `pkg-config --cflags --libs gtk+ -2.0` example -3. c

生成的 SVG 文件可以使用 Firefox、Opera、Inkscape 程序查看。

surface = cairo_svg_surface_create ( "svgfile.svg"32048 );

要生成一份 SVG 文件,必须使用 cairo_svg_surface_create () 函数创建一个 svg 外观。除此之外,其余代码的功用与上述示例类似。

本例生成的 SVG 文件,使用 Firefox 查看结果如下图所示:

4. GTK 窗口

在最后这个示例中,演示如何在 GTK 窗口中使用 Cairo 绘制图形。基于 GTK 后端的 Cairo 绘图模型将贯穿于本指南。

#include <cairo.h>
#include <gtk/gtk.h>

static gboolean
on_expose_event  (GtkWidget * widget, GdkEventExpose * event, gpointer data )
{
        cairo_t *cr;

        cr = gdk_cairo_create  (widget->window );

        cairo_set_source_rgb  (cr,  0.62700 );
        cairo_select_font_face  (cr,  "Adobe Heiti Std", CAIRO_FONT_SLANT_NORMAL,
                                CAIRO_FONT_WEIGHT_NORMAL );
        cairo_set_font_size  (cr,  24.0 );

        cairo_move_to  (cr,  10.034.0 );
        cairo_show_text  (cr,  "我是中国人,我爱我的祖国。" );

        cairo_destroy  (cr );

         return  FALSE;
}


int
main  ( int argc,  char *argv [ ] )
{

        GtkWidget *window;

        gtk_init  (&argc, &argv );

        window = gtk_window_new  (GTK_WINDOW_TOPLEVEL );

        g_signal_connect  (window,  "expose-event",
                          G_CALLBACK  (on_expose_event )NULL );
        g_signal_connect  (window,  "destroy",
                          G_CALLBACK  (gtk_main_quit )NULL );

        gtk_window_set_position  (GTK_WINDOW  (window ), GTK_WIN_POS_CENTER );
        gtk_window_set_default_size  (GTK_WINDOW  (window )32048 );
        gtk_widget_set_app_paintable  (window,  TRUE );

        gtk_widget_show_all  (window );

        gtk_main  ( );

         return  0;
}

这个示例程序运行后,会在屏幕中央跳出一个 GTK+ 窗口,上面绘制了一串文本,如下图所示:

 #include <cairo.h>
  #include <gtk/gtk.h>

首先要包含 cairo 与 gtk+ 库的头文件。

 g_signal_connect  (window,  "expose-event",
                          G_CALLBACK  (on_expose_event )NULL );

当 GTK+窗口被重绘时,会发出 expose-event 信号,我们可将这一信号连接到 on_expose_event () 回调函数上。

gtk_widget_set_app_paintable  (window,  TRUE );

要在 GTK+ 窗口中绘制 Cairo 图形,可以使用 GtkDrawingArea widget 或者更为简单的 GtkWindow widget,本例选择 GtkWindow 。由 GtkWindow widget 对 expose-event 信号处理后,默认要重新绘制窗口背景,这会将我们在 on_expose_event () 函数中定义的 Cairo 图形覆盖掉,因此需要调用 gtk_widget_set_app_paintable () 函数通知 GTK+ 不要这么干。如果是在 GtkDrawingArea widget 中绘制 Cairo 图形,则可省区这一步。

cairo_t *cr;

 cr = gdk_cairo_create  (widget->window );

Cairo 图形绘制工作是在 on_expose_event () 函数中进行的,在该函数中,我们为 GTK+ 系统创建了一个 Cairo 环境,并在该环境中绘制了一行文本。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要下载Cairo图形指南,首先需要找到可靠的来源。Cairo是一个跨平台的开源图形库,用于绘制2D向量图形。在进行下载前,可以先到Cairo官方网站(https://cairographics.org/)浏览相关信息。 在官方网站上找到"Downloads"或者"获取"的选项,点击进入下载页面。通常,下载页面会列出各种版本的Cairo图形指南可供选择。选择适合自己操作系统的版本,例如Windows、Linux或者macOS。 根据自己的操作系统,点击相应的下载链接,等待下载完成。一般来说,Cairo图形指南的下载文件以压缩包的形式提供,可以是zip文件、tar.gz文件等。如果下载的是压缩文件,需要先解压缩,可以使用系统自带的解压软件或者第三方解压工具。 解压缩完成后,就可以开始阅读Cairo图形指南了。Cairo图形指南通常以PDF、HTML或者文本格式提供,可以根据个人的喜好选择合适的格式进行阅读。可以使用电脑自带的PDF阅读器、文本编辑器等工具进行查看。 在阅读Cairo图形指南时,可以了解Cairo的基本概念、使用方法和相关的示例代码。图形指南会提供详细的说明和实例,以帮助读者更好地理解和应用Cairo图形库。 总之,要下载Cairo图形指南,需要先访问Cairo官方网站,找到适合自己操作系统的版本,下载并解压缩文件,最后选择合适的格式进行阅读。通过学习Cairo图形指南,可以更好地利用Cairo开发出高质量的2D图形应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值