Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.
 
 
 
 
 
 

680 рядки
18 KiB

  1. /*
  2. * libcucul Ruby bindings
  3. * Copyright (c) 2007 Pascal Terjan <pterjan@linuxfr.org>
  4. *
  5. * This library is free software. It comes without any warranty, to
  6. * the extent permitted by applicable law. You can redistribute it
  7. * and/or modify it under the terms of the Do What The Fuck You Want
  8. * To Public License, Version 2, as published by Sam Hocevar. See
  9. * http://sam.zoy.org/wtfpl/COPYING for more details.
  10. */
  11. #include <ruby.h>
  12. #include <cucul.h>
  13. #include <errno.h>
  14. #include "cucul-font.h"
  15. #include "common.h"
  16. VALUE cCanvas;
  17. #define simple_func(x) \
  18. static VALUE x (VALUE self) \
  19. { \
  20. if( cucul_##x (_SELF) <0) \
  21. rb_raise(rb_eRuntimeError, strerror(errno)); \
  22. \
  23. return self; \
  24. }
  25. #define get_int(x) \
  26. static VALUE get_##x (VALUE self) \
  27. { \
  28. return INT2NUM(cucul_get_##x (_SELF)); \
  29. }
  30. static void canvas_free(void * p)
  31. {
  32. cucul_free_canvas((cucul_canvas_t *)p);
  33. }
  34. static VALUE canvas_alloc(VALUE klass)
  35. {
  36. cucul_canvas_t *canvas;
  37. VALUE obj;
  38. canvas = cucul_create_canvas(0, 0);
  39. obj = Data_Wrap_Struct(klass, 0, canvas_free, canvas);
  40. return obj;
  41. }
  42. static VALUE canvas_initialize(VALUE self, VALUE width, VALUE height)
  43. {
  44. unsigned int w, h;
  45. w = NUM2INT(width);
  46. h = NUM2INT(height);
  47. cucul_set_canvas_size(_SELF, w, h);
  48. return self;
  49. }
  50. get_int(canvas_height)
  51. get_int(canvas_width)
  52. static VALUE set_canvas_width(VALUE self, VALUE width)
  53. {
  54. cucul_set_canvas_size(_SELF, NUM2INT(width), cucul_get_canvas_height(_SELF));
  55. return width;
  56. }
  57. static VALUE set_canvas_width2(VALUE self, VALUE width)
  58. {
  59. set_canvas_width(self, width);
  60. return self;
  61. }
  62. static VALUE set_canvas_height(VALUE self, VALUE height)
  63. {
  64. cucul_set_canvas_size(_SELF, cucul_get_canvas_width(_SELF), NUM2INT(height));
  65. return height;
  66. }
  67. static VALUE set_canvas_height2(VALUE self, VALUE height)
  68. {
  69. set_canvas_height(self, height);
  70. return self;
  71. }
  72. static VALUE set_canvas_size(VALUE self, VALUE height, VALUE width)
  73. {
  74. cucul_set_canvas_size(_SELF, NUM2INT(width), NUM2INT(height));
  75. return self;
  76. }
  77. /****/
  78. static VALUE gotoxy(VALUE self, VALUE x, VALUE y)
  79. {
  80. if( cucul_gotoxy(_SELF, NUM2INT(x), NUM2INT(y)) <0) {
  81. rb_raise(rb_eRuntimeError, strerror(errno));
  82. }
  83. return self;
  84. }
  85. get_int(cursor_x)
  86. get_int(cursor_y)
  87. simple_func(clear_canvas)
  88. static VALUE put_char(VALUE self, VALUE x, VALUE y, VALUE ch)
  89. {
  90. cucul_put_char(_SELF, NUM2INT(x), NUM2INT(y), NUM2ULONG(ch));
  91. return self;
  92. }
  93. static VALUE get_char(VALUE self, VALUE x, VALUE y)
  94. {
  95. unsigned long int ch;
  96. ch = cucul_get_char(_SELF, NUM2INT(x), NUM2INT(y));
  97. return INT2NUM(ch);
  98. }
  99. static VALUE put_str(VALUE self, VALUE x, VALUE y, VALUE str)
  100. {
  101. cucul_put_str(_SELF, NUM2INT(x), NUM2INT(y), StringValuePtr(str));
  102. return self;
  103. }
  104. static VALUE get_attr(VALUE self, VALUE x, VALUE y)
  105. {
  106. unsigned long int ch;
  107. ch = cucul_get_attr(_SELF, NUM2INT(x), NUM2INT(y));
  108. return INT2NUM(ch);
  109. }
  110. static VALUE set_attr(VALUE self, VALUE attr)
  111. {
  112. if(cucul_set_attr(_SELF, NUM2ULONG(attr)) <0)
  113. rb_raise(rb_eRuntimeError, strerror(errno));
  114. return self;
  115. }
  116. static VALUE set_attr2(VALUE self, VALUE attr)
  117. {
  118. set_attr(self, attr);
  119. return self;
  120. }
  121. static VALUE put_attr(VALUE self, VALUE x, VALUE y, VALUE attr)
  122. {
  123. if(cucul_put_attr(_SELF, NUM2INT(x), NUM2INT(y), NUM2ULONG(attr)) <0)
  124. rb_raise(rb_eRuntimeError, strerror(errno));
  125. return self;
  126. }
  127. static VALUE set_color_ansi(VALUE self, VALUE fg, VALUE bg)
  128. {
  129. if(cucul_set_color_ansi(_SELF, NUM2INT(fg), NUM2INT(bg)) <0)
  130. rb_raise(rb_eRuntimeError, strerror(errno));
  131. return self;
  132. }
  133. static VALUE set_color_argb(VALUE self, VALUE fg, VALUE bg)
  134. {
  135. if(cucul_set_color_argb(_SELF, NUM2UINT(fg), NUM2UINT(bg)) <0) {
  136. rb_raise(rb_eRuntimeError, strerror(errno));
  137. }
  138. return self;
  139. }
  140. static VALUE cprintf(int argc, VALUE* argv, VALUE self)
  141. {
  142. int x, y;
  143. VALUE rx, ry, format, rest, string;
  144. rb_scan_args(argc, argv, "3*", &rx, &ry, &format, &rest);
  145. x = NUM2INT(rx);
  146. y = NUM2INT(ry);
  147. string = rb_funcall2(rb_mKernel, rb_intern("sprintf"), argc-2, argv+2);
  148. cucul_put_str(_SELF, x, y, StringValuePtr(string));
  149. return self;
  150. }
  151. get_int(canvas_handle_x)
  152. get_int(canvas_handle_y)
  153. static VALUE set_canvas_handle(VALUE self, VALUE x, VALUE y)
  154. {
  155. cucul_set_canvas_handle(_SELF, NUM2INT(x), NUM2INT(y));
  156. return self;
  157. }
  158. static VALUE blit(int argc, VALUE* argv, VALUE self) {
  159. VALUE x, y, src, mask;
  160. cucul_canvas_t *csrc, *cmask;
  161. rb_scan_args(argc, argv, "31", &x, &y, &src, &mask);
  162. Check_Type(x, T_FIXNUM);
  163. Check_Type(y, T_FIXNUM);
  164. if(CLASS_OF(src) != cCanvas)
  165. {
  166. rb_raise(rb_eArgError, "src is not a Cucul::Canvas");
  167. }
  168. Data_Get_Struct(src, cucul_canvas_t, csrc);
  169. if(!NIL_P(mask))
  170. {
  171. if(CLASS_OF(mask) != cCanvas)
  172. {
  173. rb_raise(rb_eArgError, "mask is not a Cucul::Canvas");
  174. }
  175. Data_Get_Struct(mask, cucul_canvas_t, cmask);
  176. }
  177. else
  178. cmask = NULL;
  179. if(cucul_blit(_SELF, NUM2INT(x), NUM2INT(y), csrc, cmask)<0)
  180. rb_raise(rb_eRuntimeError, strerror(errno));
  181. return self;
  182. }
  183. static VALUE set_canvas_boundaries(VALUE self, VALUE x, VALUE y, VALUE w, VALUE h)
  184. {
  185. if(cucul_set_canvas_boundaries(_SELF, NUM2INT(x), NUM2INT(y), NUM2UINT(w), NUM2UINT(h))<0)
  186. {
  187. rb_raise(rb_eRuntimeError, strerror(errno));
  188. }
  189. return self;
  190. }
  191. /****/
  192. simple_func(invert)
  193. simple_func(flip)
  194. simple_func(flop)
  195. simple_func(rotate_180)
  196. simple_func(rotate_left)
  197. simple_func(rotate_right)
  198. simple_func(stretch_left)
  199. simple_func(stretch_right)
  200. /****/
  201. static VALUE draw_line(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2, VALUE ch)
  202. {
  203. cucul_draw_line(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2),NUM2ULONG(ch));
  204. return self;
  205. }
  206. static VALUE draw_polyline(VALUE self, VALUE points, VALUE ch)
  207. {
  208. int i, n;
  209. int *ax, *ay;
  210. int error = 0;
  211. VALUE v, x, y;
  212. n = RARRAY(points)->len;
  213. ax = (int*)malloc(n*sizeof(int));
  214. if(!ax)
  215. rb_raise(rb_eNoMemError,"Out of memory");
  216. ay = (int*)malloc(n*sizeof(int));
  217. if(!ay)
  218. {
  219. free(ax);
  220. rb_raise(rb_eNoMemError,"Out of memory");
  221. }
  222. for(i=0; i<n; i++)
  223. {
  224. v = rb_ary_entry(points, i);
  225. if((TYPE(v) == T_ARRAY) && (RARRAY(v)->len == 2))
  226. {
  227. x = rb_ary_entry(v,0);
  228. y = rb_ary_entry(v,1);
  229. if(rb_obj_is_kind_of(x, rb_cInteger) &&
  230. rb_obj_is_kind_of(y, rb_cInteger))
  231. {
  232. ax[i] = NUM2INT(x);
  233. ay[i] = NUM2INT(y);
  234. } else
  235. error = 1;
  236. }
  237. else
  238. error = 1;
  239. }
  240. if(error)
  241. {
  242. free(ax);
  243. free(ay);
  244. rb_raise(rb_eArgError, "Invalid list of points");
  245. }
  246. n--;
  247. cucul_draw_polyline(_SELF, ax, ay, n, NUM2ULONG(ch));
  248. free(ax);
  249. free(ay);
  250. return self;
  251. }
  252. static VALUE draw_thin_line(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2)
  253. {
  254. cucul_draw_thin_line(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2));
  255. return self;
  256. }
  257. static VALUE draw_thin_polyline(VALUE self, VALUE points)
  258. {
  259. int i, n;
  260. int *ax, *ay;
  261. int error = 0;
  262. VALUE v, x, y;
  263. n = RARRAY(points)->len;
  264. ax = (int*)malloc(n*sizeof(int));
  265. if(!ax)
  266. rb_raise(rb_eNoMemError,"Out of memory");
  267. ay = (int*)malloc(n*sizeof(int));
  268. if(!ay)
  269. {
  270. free(ax);
  271. rb_raise(rb_eNoMemError,"Out of memory");
  272. }
  273. for(i=0; i<n; i++)
  274. {
  275. v = rb_ary_entry(points, i);
  276. if((TYPE(v) == T_ARRAY) && (RARRAY(v)->len == 2))
  277. {
  278. x = rb_ary_entry(v,0);
  279. y = rb_ary_entry(v,1);
  280. if(rb_obj_is_kind_of(x, rb_cInteger) &&
  281. rb_obj_is_kind_of(y, rb_cInteger))
  282. {
  283. ax[i] = NUM2INT(x);
  284. ay[i] = NUM2INT(y);
  285. } else
  286. error = 1;
  287. }
  288. else
  289. error = 1;
  290. }
  291. if(error)
  292. {
  293. free(ax);
  294. free(ay);
  295. rb_raise(rb_eArgError, "Invalid list of points");
  296. }
  297. n--;
  298. cucul_draw_thin_polyline(_SELF, ax, ay, n);
  299. free(ax);
  300. free(ay);
  301. return self;
  302. }
  303. static VALUE draw_circle(VALUE self, VALUE x, VALUE y, VALUE r, VALUE ch)
  304. {
  305. cucul_draw_circle(_SELF, NUM2INT(x), NUM2INT(y), NUM2INT(r), NUM2ULONG(ch));
  306. return self;
  307. }
  308. static VALUE draw_ellipse(VALUE self, VALUE x, VALUE y, VALUE a, VALUE b, VALUE ch)
  309. {
  310. cucul_draw_ellipse(_SELF, NUM2INT(x), NUM2INT(y), NUM2INT(a), NUM2INT(b), NUM2ULONG(ch));
  311. return self;
  312. }
  313. static VALUE draw_thin_ellipse(VALUE self, VALUE x, VALUE y, VALUE a, VALUE b)
  314. {
  315. cucul_draw_thin_ellipse(_SELF, NUM2INT(x), NUM2INT(y), NUM2INT(a), NUM2INT(b));
  316. return self;
  317. }
  318. static VALUE fill_ellipse(VALUE self, VALUE x, VALUE y, VALUE a, VALUE b, VALUE ch)
  319. {
  320. cucul_fill_ellipse(_SELF, NUM2INT(x), NUM2INT(y), NUM2INT(a), NUM2INT(b), NUM2ULONG(ch));
  321. return self;
  322. }
  323. static VALUE draw_box(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2, VALUE ch)
  324. {
  325. cucul_draw_box(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2), NUM2ULONG(ch));
  326. return self;
  327. }
  328. static VALUE draw_thin_box(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2)
  329. {
  330. cucul_draw_thin_box(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2));
  331. return self;
  332. }
  333. static VALUE draw_cp437_box(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2)
  334. {
  335. cucul_draw_cp437_box(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2));
  336. return self;
  337. }
  338. static VALUE fill_box(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2, VALUE ch)
  339. {
  340. cucul_fill_box(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2), NUM2ULONG(ch));
  341. return self;
  342. }
  343. static VALUE draw_triangle(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2, VALUE x3, VALUE y3, VALUE ch)
  344. {
  345. cucul_draw_triangle(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2), NUM2INT(x3), NUM2INT(y3), NUM2ULONG(ch));
  346. return self;
  347. }
  348. static VALUE draw_thin_triangle(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2, VALUE x3, VALUE y3)
  349. {
  350. cucul_draw_thin_triangle(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2), NUM2INT(x3), NUM2INT(y3));
  351. return self;
  352. }
  353. static VALUE fill_triangle(VALUE self, VALUE x1, VALUE y1, VALUE x2, VALUE y2, VALUE x3, VALUE y3, VALUE ch)
  354. {
  355. cucul_fill_triangle(_SELF, NUM2INT(x1), NUM2INT(y1), NUM2INT(x2), NUM2INT(y2), NUM2INT(x3), NUM2INT(y3), NUM2ULONG(ch));
  356. return self;
  357. }
  358. /****/
  359. get_int(frame_count)
  360. static VALUE set_frame(VALUE self, VALUE id)
  361. {
  362. if(cucul_set_frame(_SELF, NUM2INT(id))<0)
  363. rb_raise(rb_eArgError, strerror(errno));
  364. return self;
  365. }
  366. static VALUE set_frame2(VALUE self, VALUE id)
  367. {
  368. set_frame(self, id);
  369. return self;
  370. }
  371. static VALUE get_frame_name(VALUE self)
  372. {
  373. return rb_str_new2(cucul_get_frame_name(_SELF));
  374. }
  375. static VALUE set_frame_name(VALUE self, VALUE name)
  376. {
  377. if(cucul_set_frame_name(_SELF, StringValuePtr(name))<0)
  378. rb_raise(rb_eRuntimeError, strerror(errno));
  379. return self;
  380. }
  381. static VALUE set_frame_name2(VALUE self, VALUE name)
  382. {
  383. set_frame_name(self, name);
  384. return self;
  385. }
  386. static VALUE create_frame(VALUE self, VALUE id)
  387. {
  388. if(cucul_create_frame(_SELF, NUM2INT(id))<0) {
  389. rb_raise(rb_eRuntimeError, strerror(errno));
  390. }
  391. return self;
  392. }
  393. static VALUE free_frame(VALUE self, VALUE id)
  394. {
  395. if(cucul_free_frame(_SELF, NUM2INT(id))<0) {
  396. rb_raise(rb_eArgError, strerror(errno));
  397. }
  398. return self;
  399. }
  400. /****/
  401. static VALUE render_canvas(VALUE self, VALUE font, VALUE width, VALUE height, VALUE pitch)
  402. {
  403. void *buf;
  404. cucul_font_t *f;
  405. VALUE b;
  406. if(CLASS_OF(font) != cFont)
  407. {
  408. rb_raise(rb_eArgError, "First argument is not a Cucul::Font");
  409. }
  410. buf = malloc(width*height*4);
  411. if(buf == NULL)
  412. {
  413. rb_raise(rb_eNoMemError, "Out of memory");
  414. }
  415. f = DATA_PTR(font);
  416. cucul_render_canvas(_SELF, f, buf, NUM2UINT(width), NUM2UINT(height), NUM2UINT(pitch));
  417. b = rb_str_new(buf, width*height*4);
  418. free(buf);
  419. return b;
  420. }
  421. static VALUE import_memory(VALUE self, VALUE data, VALUE format)
  422. {
  423. long int bytes;
  424. bytes = cucul_import_memory (_SELF, StringValuePtr(data), RSTRING(StringValue(data))->len, StringValuePtr(format));
  425. if(bytes <= 0)
  426. rb_raise(rb_eRuntimeError, strerror(errno));
  427. return self;
  428. }
  429. static VALUE import_file(VALUE self, VALUE filename, VALUE format)
  430. {
  431. long int bytes;
  432. bytes = cucul_import_file (_SELF, StringValuePtr(filename), StringValuePtr(format));
  433. if(bytes <= 0)
  434. rb_raise(rb_eRuntimeError, strerror(errno));
  435. return self;
  436. }
  437. static VALUE export_memory(VALUE self, VALUE format)
  438. {
  439. unsigned long int bytes;
  440. void *result;
  441. VALUE ret;
  442. result = cucul_export_memory (_SELF, StringValuePtr(format), &bytes);
  443. ret = rb_str_new(result, bytes);
  444. free(result);
  445. return ret;
  446. }
  447. static VALUE export_list(void)
  448. {
  449. VALUE ary, ary2;
  450. char const* const* list;
  451. list = cucul_get_export_list();
  452. ary = rb_ary_new();
  453. while (*list != NULL)
  454. {
  455. ary2 = rb_ary_new();
  456. rb_ary_push(ary2, rb_str_new2(*list));
  457. list++;
  458. rb_ary_push(ary2, rb_str_new2(*list));
  459. list++;
  460. rb_ary_push(ary, ary2);
  461. }
  462. return ary;
  463. }
  464. static VALUE import_list(void)
  465. {
  466. VALUE ary, ary2;
  467. char const* const* list;
  468. list = cucul_get_import_list();
  469. ary = rb_ary_new();
  470. while (*list != NULL)
  471. {
  472. ary2 = rb_ary_new();
  473. rb_ary_push(ary2, rb_str_new2(*list));
  474. list++;
  475. rb_ary_push(ary2, rb_str_new2(*list));
  476. list++;
  477. rb_ary_push(ary, ary2);
  478. }
  479. return ary;
  480. }
  481. /****/
  482. void Init_cucul_canvas(VALUE mCucul)
  483. {
  484. cCanvas = rb_define_class_under(mCucul, "Canvas", rb_cObject);
  485. rb_define_alloc_func(cCanvas, canvas_alloc);
  486. rb_define_method(cCanvas, "initialize", canvas_initialize, 2);
  487. rb_define_method(cCanvas, "width", get_canvas_width, 0);
  488. rb_define_method(cCanvas, "width=", set_canvas_width, 1);
  489. rb_define_method(cCanvas, "set_width", set_canvas_width2, 1);
  490. rb_define_method(cCanvas, "height", get_canvas_height, 0);
  491. rb_define_method(cCanvas, "height=", set_canvas_height, 1);
  492. rb_define_method(cCanvas, "set_height", set_canvas_height2, 1);
  493. rb_define_method(cCanvas, "set_size", set_canvas_size, 2);
  494. rb_define_method(cCanvas, "gotoxy", gotoxy, 2);
  495. rb_define_method(cCanvas, "cursor_x", get_cursor_x, 0);
  496. rb_define_method(cCanvas, "cursor_y", get_cursor_y, 0);
  497. rb_define_method(cCanvas, "handle_x", get_canvas_handle_x, 0);
  498. rb_define_method(cCanvas, "handle_y", get_canvas_handle_y, 0);
  499. rb_define_method(cCanvas, "set_handle", set_canvas_handle, 2);
  500. rb_define_method(cCanvas, "blit", blit, -1);
  501. rb_define_method(cCanvas, "set_boundaries", set_canvas_boundaries, 4);
  502. rb_define_method(cCanvas, "clear", clear_canvas, 0);
  503. rb_define_method(cCanvas, "put_char", put_char, 3);
  504. rb_define_method(cCanvas, "get_char", get_char, 2);
  505. rb_define_method(cCanvas, "put_str", put_str, 3);
  506. rb_define_method(cCanvas, "printf", cprintf, -1);
  507. rb_define_method(cCanvas, "get_attr", get_attr, 3);
  508. rb_define_method(cCanvas, "attr=", set_attr, 1);
  509. rb_define_method(cCanvas, "set_attr", set_attr2, 1);
  510. rb_define_method(cCanvas, "put_attr", put_attr, 3);
  511. rb_define_method(cCanvas, "set_color_ansi", set_color_ansi, 2);
  512. rb_define_method(cCanvas, "set_color_argb", set_color_argb, 2);
  513. rb_define_method(cCanvas, "invert", invert, 0);
  514. rb_define_method(cCanvas, "flip", flip, 0);
  515. rb_define_method(cCanvas, "flop", flop, 0);
  516. rb_define_method(cCanvas, "rotate_180", rotate_180, 0);
  517. rb_define_method(cCanvas, "rotate_left", rotate_left, 0);
  518. rb_define_method(cCanvas, "rotate_right", rotate_right, 0);
  519. rb_define_method(cCanvas, "stretch_left", stretch_left, 0);
  520. rb_define_method(cCanvas, "stretch_right", stretch_right, 0);
  521. rb_define_method(cCanvas, "draw_line", draw_line, 5);
  522. rb_define_method(cCanvas, "draw_polyline", draw_polyline, 2);
  523. rb_define_method(cCanvas, "draw_thin_line", draw_thin_line, 4);
  524. rb_define_method(cCanvas, "draw_thin_polyline", draw_thin_polyline, 1);
  525. rb_define_method(cCanvas, "draw_circle", draw_circle, 4);
  526. rb_define_method(cCanvas, "draw_ellipse", draw_ellipse, 5);
  527. rb_define_method(cCanvas, "draw_thin_ellipse", draw_thin_ellipse, 4);
  528. rb_define_method(cCanvas, "fill_ellipse", fill_ellipse, 5);
  529. rb_define_method(cCanvas, "draw_box", draw_box, 5);
  530. rb_define_method(cCanvas, "draw_thin_box", draw_thin_box, 4);
  531. rb_define_method(cCanvas, "draw_cp437_box", draw_cp437_box, 4);
  532. rb_define_method(cCanvas, "fill_box", fill_box, 5);
  533. rb_define_method(cCanvas, "draw_triangle", draw_triangle, 7);
  534. rb_define_method(cCanvas, "draw_thin_triangle", draw_thin_triangle, 6);
  535. rb_define_method(cCanvas, "fill_triangle", fill_triangle, 7);
  536. rb_define_method(cCanvas, "frame_count", get_frame_count, 0);
  537. rb_define_method(cCanvas, "frame=", set_frame, 1);
  538. rb_define_method(cCanvas, "set_frame", set_frame2, 1);
  539. rb_define_method(cCanvas, "frame_name", get_frame_name, 0);
  540. rb_define_method(cCanvas, "frame_name=", set_frame_name, 1);
  541. rb_define_method(cCanvas, "set_frame_name", set_frame_name2, 1);
  542. rb_define_method(cCanvas, "create_frame", create_frame, 1);
  543. rb_define_method(cCanvas, "free_frame", free_frame, 1);
  544. rb_define_method(cCanvas, "render", render_canvas, 4);
  545. rb_define_method(cCanvas, "import_memory", import_memory, 2);
  546. rb_define_method(cCanvas, "import_file", import_file, 2);
  547. rb_define_method(cCanvas, "export_memory", export_memory, 1);
  548. rb_define_singleton_method(cCanvas, "export_list", export_list, 0);
  549. rb_define_singleton_method(cCanvas, "import_list", import_list, 0);
  550. }