ソフトウェア設計及び演習2016
GDK2016::Cairo
GDKドローアブルとCairo
ドローアブルからサーフェス&コンテキストを作成する
cairo_t* gdk_cairo_create (GdkDrawable *drawable);
-
gdk_cairo_create
- 入門GTK+ 3版pdf:82(94)ページ
コンテキストは使い終わったら破棄すること
void cairo_destroy (cairo_t *cr);
ソース
単色
- 光の三原色:赤(red:R)、緑(green:G)、青(blue:B)で表現
- RGBの各成分の含まれる割合を0.0~1.0で表す
-色- | -R- | -G- | -B- |
黒 | 0.0 | 0.0 | 0.0 |
白 | 1.0 | 1.0 | 1.0 |
赤 | 1.0 | 0.0 | 0.0 |
緑 | 0.0 | 1.0 | 0.0 |
青 | 0.0 | 0.0 | 1.0 |
黄 | 1.0 | 1.0 | 0.0 |
void cairo_set_source_rgb (cairo_t *cr, double red, double green, double blue);
-
cairo_set_source_rgb
- 入門GTK+ 3版pdf:94(106)ページ
void cairo_set_source_rgba (cairo_t *cr, double red, double green, double blue, double alpha);
-
cairo_set_source_rgba
- 入門GTK+ 3版pdf:94(106)ページ
- alphaは透明度.0.0で透明,1.0で不透明.
画像
- GdkPixbuf
- ピクスマップ
- サーフェス
void gdk_cairo_set_source_pixbuf (cairo_t *cr, const GdkPixbuf *pixbuf, double pixbuf_x, double pixbuf_y);
-
gdk_cairo_set_source_pixbuf
- 入門GTK+ 3版pdf:99(111)ページ
void gdk_cairo_set_source_pixmap (cairo_t *cr, GdkPixmap *pixmap, double pixmap_x, double pixmap_y);
void cairo_set_source_surface (cairo_t *cr, cairo_surface_t *surface, double x, double y);
-
cairo_set_source_surface
- 入門GTK+ 3版pdf:101(113)ページ
パス
線の形状
- 線の太さ,角や端の形状,点線
void cairo_set_line_width (cairo_t *cr, double width);
-
cairo_set_line_width
- 入門GTK+ 3版pdf:85(97)ページ
void cairo_set_line_cap (cairo_t *cr, cairo_line_cap_t line_cap);
- cairo_set_line_cap
- cairo_line_cap_t
- 入門GTK+ 3版pdf:85(97)ページ
void cairo_set_line_join (cairo_t *cr, cairo_line_join_t line_join);
- cairo_set_line_join
- cairo_line_join_t
- 入門GTK+ 3版pdf:87(99)ページ
void cairo_set_dash (cairo_t *cr, const double *dashes, int num_dashes, double offset);
-
cairo_set_dash
- 入門GTK+ 3版pdf:88(100)ページ
直線
- cairo_move_to()で始点に移動し,cairo_line_to()で示す終点まで線を引く
- cairo_line_to()を続ければ折れ線が引かれていく
- 最後にcairo_stroke()を読んだ時点で実際に描かれる
void cairo_move_to (cairo_t *cr, double x, double y);
-
cairo_move_to
- 入門GTK+ 3版pdf:84(96)ページ
void cairo_line_to (cairo_t *cr, double x, double y);
-
cairo_line_to
- 入門GTK+ 3版pdf:85(97)ページ
void cairo_stroke (cairo_t *cr);
-
cairo_stroke
- 入門GTK+ 3版pdf:85(97)ページ
矩形
- 塗りつぶしたいときはcairo_stroke()の代わりにcairo_fill()を呼ぶ
- 枠を描いて,さらに塗りつぶしたいときは
- 先に枠を描く場合,cairo_stroke_preserve(),cairo_fill()の順に
- 先に塗りつぶす場合,cairo_fill_preserve(),cairo_stroke()の順に
- どちらを先に描くかで結果が違う
- _preserveを付けないと,cairo_stroke()やcairo_fill()を読んだ時点でパスは再利用できなくなる
void cairo_rectangle (cairo_t *cr, double x, double y, double width, double height);
-
cairo_rectangle
- 入門GTK+ 3版pdf:89(101)ページ
void cairo_fill (cairo_t *cr);
-
cairo_fill
- 入門GTK+ 3版pdf:89(101)ページ
void cairo_stroke_preserve (cairo_t *cr);
-
cairo_stroke_preserve
- 入門GTK+ 3版pdf:85(97)ページ
void cairo_fill_preserve (cairo_t *cr);
-
cairo_fill_preserve
- 入門GTK+ 3版pdf:89(101)ページ
円弧
- 中心と半径で表現
- 角度は3時の位置が0で時計回り.単位はラジアン
void cairo_arc (cairo_t *cr, double xc, double yc, double radius, double angle1, double angle2);
-
cairo_arc
- 入門GTK+ 3版pdf:92(104)ページ
曲線
- 制御点が2つのベジエ曲線
void cairo_curve_to (cairo_t *cr, double x1, double y1, double x2, double y2, double x3, double y3);
-
cairo_curve_to
- 入門GTK+ 3版pdf:93(105)ページ
多角形
- 基本的にcairo_line_to()を続けて折れ線で描く
- 途中,cairo_curve_to()で曲線も可
- 閉じた図形にするときは,cairo_close_path()を使う
void cairo_close_path (cairo_t *cr);
-
cairo_close_path
- 入門GTK+ 3版pdf:90(102)ページ
塗りつぶし
- サーフェスを全てソースで塗りつぶす
void cairo_paint (cairo_t *cr);
-
cairo_paint
- 入門GTK+ 3版pdf:99(111)ページ
void cairo_paint_with_alpha (cairo_t *cr, double alpha);
-
cairo_paint_with_alpha
- 入門GTK+ 3版pdf:99(111)ページ
- 透明度付き
座標系の変換
- 平行移動
void cairo_translate (cairo_t *cr, double tx, double ty);
-
cairo_translate
- 入門GTK+ 3版pdf:103(115)ページ 座標系を変換する前にcairo_save()することで座標系を保存し, 処理が全て終わったらcairo_restore()すれば変換前の状態に戻すことができる
void cairo_save (cairo_t *cr);
void cairo_restore (cairo_t *cr);
最終更新日:2015/03/05 10:01:27