cairo 教程5

编译过程可参考教程二

基本绘图

这一部分讲述如何绘制一些简单的图元,包括直线、填充与笔画操作、虚线、线端(Cap)与线的交合等图形的绘制方法。

直线段

直线段是非常基础的矢量图形对象。画一条直线段,需要调用两个函数:cairo_move_to()函数,用于设置线段起点;cairo_line_to()用于设定线段终点。

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

double coordx[100] ;
double coordy[100] ;

int count = 0 ;

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 , 0 , 0) ;
        cairo_set_line_width
( cr, 0.5) ;
       
       
int i, j;
       
for( i = 0 ; i <= count - 1 ; i++ ){
               
for( j  = 0 ; j <= count -1 ; j++ ){
                       cairo_move_to
( cr,coordx[ i] , coordy[ i]) ;
                       cairo_line_to
( cr,coordx[ j] , coordy[ j]) ;
               
}
       
}
       
        count =
0 ;
        cairo_stroke
( cr) ;
        cairo_destroy
( cr) ;
       
       
returnFALSE ;
}

gboolean clicked
( GtkWidget*widget, GdkEventButton *event,
                 gpointeruser_data
)
{
       
if(event->button == 1){
                coordx
[ count] = event->x;
                coordy
[ count++] = event->y;
       
}
       
       
if(event->button == 3){
                gtk_widget_queue_draw
( widget) ;
       
}
       
       
returnTRUE ;
}


int
main
(int argc, char *argv[])
{
       
        GtkWidget *window;
       
        gtk_init
( &argc, &argv) ;
       
        window = gtk_window_new
( GTK_WINDOW_TOPLEVEL) ;
       
        gtk_widget_add_events
( window, GDK_BUTTON_PRESS_MASK) ;
       
        g_signal_connect
( window, "expose-event" ,
                        G_CALLBACK
(on_expose_event) , NULL) ;
        g_signal_connect
( window, "destroy" ,
                        G_CALLBACK
(gtk_main_quit) , NULL) ;
        g_signal_connect
( window, "button-press-event" ,
                        G_CALLBACK
( clicked) , NULL) ;
       
        gtk_window_set_position
( GTK_WINDOW( window) , GTK_WIN_POS_CENTER) ;
        gtk_window_set_title
( GTK_WINDOW( window) , "lines") ;
        gtk_window_set_default_size
( GTK_WINDOW( window) , 400 , 300) ;
        gtk_widget_set_app_paintable
( window, TRUE) ;
       
        gtk_widget_show_all
( window) ;
       
        gtk_main
() ;
       
       
return0 ;
}

该示例会创建一个支持鼠标交互绘制直线段的 GTK+ 窗口。在窗口中使用鼠标左键随便点几下,每一次点击时,光标位置的坐标都会被记入长度为 100 的数组;然后点击鼠标右键,所有由鼠标左键点击所得到的点会被彼此连接形成直线段;在窗口中再次点击鼠标右键时,会对窗口绘图区域进行清除。

下面对该示例程序代码进行分析:


       cairo_set_source_rgb( cr, 0 , 0 , 0) ;
        cairo_set_line_width
( cr, 0.5) ;

设置颜色为黑色,线宽为 0.5pt 为参数,绘制直线段。


       int i, j;
       
for( i = 0 ; i <= count - 1 ; i++ ){
               
for( j  = 0 ; j <= count -1 ; j++ ){
                       cairo_move_to
( cr,coordx[ i] , coordy[ i]) ;
                       cairo_line_to
( cr,coordx[ j] , coordy[ j]) ;
               
}
       
}

cairo_move_to() cairo_line_to() 函数在 cr 中定义绘图路径 (path),连接 coordx[] coordy[] 所记录的每个点。


       cairo_stroke( cr) ;

cairo_stroke() 函数会将 cr 中的路径绘制出来。


       g_signal_connect( window, "button-press-event" ,
                        G_CALLBACK
( clicked) , NULL) ;

设定button-press-event事件的回调函数为clicked ()


       if( event->button == 1){
                coordx
[ count] = event->x;
                coordy
[ count++] = event->y;
       
}

clicked ()函数中,当鼠标左键点击事件发生时,讲光标所在位置的 x y 坐标分别记入数组coordx 和 coordy 。


       if( event->button == 3){
                gtk_widget_queue_draw
( widget) ;
       
}

 clicked ()函数中,当鼠标右键单击时,调用 gtk_widget_queue_draw () 函数重绘窗口区域。


                               

Cairo 概念 ................................................................................................................................... 3 环境 (Context) ............................................................................................................................. 3 路径 (Path) ................................................................................................................................... 3 源 (Source) ................................................................................................................................... 3 外观 (Surface) .............................................................................................................................. 3 蒙板 (Mask) ................................................................................................................................. 4 图案 (Pattern) ............................................................................................................................... 4 二Cairo 后端 ................................................................................................................................... 4 1. PNG 图像 ................................................................................................................................. 4 2. PDF 文件 ................................................................................................................................. 5 3. SVG 文件 ................................................................................................................................. 6 4. GTK 窗口 ................................................................................................................................ 7 三 基本绘图 ..................................................................................................................................... 9 直线段 .......................................................................................................................................... 9 描绘 (Stroke) 与填充 (Fill) ..................................................................................................... 12 虚线 (Dash) ................................................................................................................................ 14 线帽 (Line caps) ........................................................................................................................ 17 线的交合 (Line joins) ................................................................................................................ 19 四 高级形状绘制 ........................................................................................................................... 21 基本形状..................................................................................................................................... 21 复杂的图形................................................................................................................................. 24 填充 (Fill) .................................................................................................................................. 27 纯色 (Solid color) .................................................................................................................. 27 图案 (Pattern) ......................................................................................................................... 28 渐变 (Gradient) ...................................................................................................................... 32 五 透明........................................................................................................................................... 35 透明的矩形................................................................................................................................. 35 淡出的效果................................................................................................................................. 37 “等待”的演示 ............................................................................................................................. 40 六 合成........................................................................................................................................... 43 七 裁剪与遮蔽 ............................................................................................................................... 46 裁剪 ............................................................................................................................................ 46 裁剪矩形..................................................................................................................................... 49 遮蔽 ............................................................................................................................................ 53 变换 ............................................................................................................................................ 55 平移......................................................................................................................................... 55 旋转......................................................................................................................................... 56 缩放......................................................................................................................................... 58 错切......................................................................................................................................... 60 椭圆......................................................................................................................................... 63 星星......................................................................................................................................... 65 七 文本........................................................................................................................................... 68 灵魂伙伴..................................................................................................................................... 68 一个字接一个字…… ................................................................................................................. 71 膨胀 ............................................................................................................................................ 73 八 图像........................................................................................................................................... 76 图像的显示................................................................................................................................. 77 垂帘效果(Blind Down) ......................................................................................................... 78 光谱效果..................................................................................................................................... 81
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值