rdp-rmagick 0.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (388) hide show
  1. data/ChangeLog +769 -0
  2. data/Doxyfile +1514 -0
  3. data/README-Mac-OSX.txt +1 -0
  4. data/README.md +231 -0
  5. data/build_tarball.rake +215 -0
  6. data/doc/comtasks.html +287 -0
  7. data/doc/constants.html +1581 -0
  8. data/doc/css/doc.css +299 -0
  9. data/doc/css/popup.css +34 -0
  10. data/doc/css/ref.css +67 -0
  11. data/doc/draw.html +3269 -0
  12. data/doc/ex/InitialCoords.rb +23 -0
  13. data/doc/ex/NewCoordSys.rb +32 -0
  14. data/doc/ex/OrigCoordSys.rb +18 -0
  15. data/doc/ex/PreserveAspectRatio.rb +205 -0
  16. data/doc/ex/RotateScale.rb +37 -0
  17. data/doc/ex/Skew.rb +38 -0
  18. data/doc/ex/Use01.rb +16 -0
  19. data/doc/ex/Use02.rb +21 -0
  20. data/doc/ex/Use03.rb +16 -0
  21. data/doc/ex/ViewBox.rb +33 -0
  22. data/doc/ex/adaptive_threshold.rb +10 -0
  23. data/doc/ex/add_noise.rb +17 -0
  24. data/doc/ex/affine.rb +48 -0
  25. data/doc/ex/affine_transform.rb +20 -0
  26. data/doc/ex/arc.rb +49 -0
  27. data/doc/ex/arcpath.rb +33 -0
  28. data/doc/ex/arcs01.rb +28 -0
  29. data/doc/ex/arcs02.rb +61 -0
  30. data/doc/ex/average.rb +15 -0
  31. data/doc/ex/axes.rb +64 -0
  32. data/doc/ex/baseline_shift01.rb +18 -0
  33. data/doc/ex/bilevel_channel.rb +9 -0
  34. data/doc/ex/blur_image.rb +12 -0
  35. data/doc/ex/border.rb +10 -0
  36. data/doc/ex/bounding_box.rb +44 -0
  37. data/doc/ex/cbezier1.rb +42 -0
  38. data/doc/ex/cbezier2.rb +42 -0
  39. data/doc/ex/cbezier3.rb +42 -0
  40. data/doc/ex/cbezier4.rb +43 -0
  41. data/doc/ex/cbezier5.rb +43 -0
  42. data/doc/ex/cbezier6.rb +53 -0
  43. data/doc/ex/channel.rb +26 -0
  44. data/doc/ex/charcoal.rb +12 -0
  45. data/doc/ex/chop.rb +29 -0
  46. data/doc/ex/circle.rb +33 -0
  47. data/doc/ex/circle01.rb +17 -0
  48. data/doc/ex/clip_path.rb +60 -0
  49. data/doc/ex/coalesce.rb +60 -0
  50. data/doc/ex/color_fill_to_border.rb +29 -0
  51. data/doc/ex/color_floodfill.rb +28 -0
  52. data/doc/ex/color_histogram.rb +48 -0
  53. data/doc/ex/color_reset.rb +11 -0
  54. data/doc/ex/colorize.rb +16 -0
  55. data/doc/ex/colors.rb +64 -0
  56. data/doc/ex/compose_mask.rb +23 -0
  57. data/doc/ex/composite.rb +135 -0
  58. data/doc/ex/composite_layers.rb +53 -0
  59. data/doc/ex/composite_tiled.rb +23 -0
  60. data/doc/ex/contrast.rb +36 -0
  61. data/doc/ex/crop.rb +31 -0
  62. data/doc/ex/crop_with_gravity.rb +46 -0
  63. data/doc/ex/cubic01.rb +45 -0
  64. data/doc/ex/cubic02.rb +94 -0
  65. data/doc/ex/cycle_colormap.rb +21 -0
  66. data/doc/ex/dissolve.rb +13 -0
  67. data/doc/ex/drawcomp.rb +42 -0
  68. data/doc/ex/drop_shadow.rb +60 -0
  69. data/doc/ex/edge.rb +11 -0
  70. data/doc/ex/ellipse.rb +45 -0
  71. data/doc/ex/ellipse01.rb +22 -0
  72. data/doc/ex/emboss.rb +11 -0
  73. data/doc/ex/enhance.rb +28 -0
  74. data/doc/ex/equalize.rb +11 -0
  75. data/doc/ex/evenodd.rb +43 -0
  76. data/doc/ex/fill_pattern.rb +26 -0
  77. data/doc/ex/flatten_images.rb +36 -0
  78. data/doc/ex/flip.rb +11 -0
  79. data/doc/ex/flop.rb +11 -0
  80. data/doc/ex/font_styles.rb +34 -0
  81. data/doc/ex/fonts.rb +20 -0
  82. data/doc/ex/frame.rb +12 -0
  83. data/doc/ex/gaussian_blur.rb +11 -0
  84. data/doc/ex/get_multiline_type_metrics.rb +42 -0
  85. data/doc/ex/get_pixels.rb +48 -0
  86. data/doc/ex/get_type_metrics.rb +146 -0
  87. data/doc/ex/gradientfill.rb +27 -0
  88. data/doc/ex/grav.rb +46 -0
  89. data/doc/ex/gravity.rb +79 -0
  90. data/doc/ex/group.rb +26 -0
  91. data/doc/ex/hatchfill.rb +27 -0
  92. data/doc/ex/image.rb +46 -0
  93. data/doc/ex/images/Apple.miff +0 -0
  94. data/doc/ex/images/Ballerina.jpg +0 -0
  95. data/doc/ex/images/Ballerina3.jpg +0 -0
  96. data/doc/ex/images/Button_0.gif +0 -0
  97. data/doc/ex/images/Button_1.gif +0 -0
  98. data/doc/ex/images/Button_2.gif +0 -0
  99. data/doc/ex/images/Button_3.gif +0 -0
  100. data/doc/ex/images/Button_4.gif +0 -0
  101. data/doc/ex/images/Button_5.gif +0 -0
  102. data/doc/ex/images/Button_6.gif +0 -0
  103. data/doc/ex/images/Button_7.gif +0 -0
  104. data/doc/ex/images/Button_8.gif +0 -0
  105. data/doc/ex/images/Button_9.gif +0 -0
  106. data/doc/ex/images/Button_A.gif +0 -0
  107. data/doc/ex/images/Button_B.gif +0 -0
  108. data/doc/ex/images/Button_C.gif +0 -0
  109. data/doc/ex/images/Button_D.gif +0 -0
  110. data/doc/ex/images/Button_E.gif +0 -0
  111. data/doc/ex/images/Button_F.gif +0 -0
  112. data/doc/ex/images/Button_G.gif +0 -0
  113. data/doc/ex/images/Button_H.gif +0 -0
  114. data/doc/ex/images/Button_I.gif +0 -0
  115. data/doc/ex/images/Button_J.gif +0 -0
  116. data/doc/ex/images/Button_K.gif +0 -0
  117. data/doc/ex/images/Button_L.gif +0 -0
  118. data/doc/ex/images/Button_M.gif +0 -0
  119. data/doc/ex/images/Button_N.gif +0 -0
  120. data/doc/ex/images/Button_O.gif +0 -0
  121. data/doc/ex/images/Button_P.gif +0 -0
  122. data/doc/ex/images/Button_Q.gif +0 -0
  123. data/doc/ex/images/Button_R.gif +0 -0
  124. data/doc/ex/images/Button_S.gif +0 -0
  125. data/doc/ex/images/Button_T.gif +0 -0
  126. data/doc/ex/images/Button_U.gif +0 -0
  127. data/doc/ex/images/Button_V.gif +0 -0
  128. data/doc/ex/images/Button_W.gif +0 -0
  129. data/doc/ex/images/Button_X.gif +0 -0
  130. data/doc/ex/images/Button_Y.gif +0 -0
  131. data/doc/ex/images/Button_Z.gif +0 -0
  132. data/doc/ex/images/Cheetah.jpg +0 -0
  133. data/doc/ex/images/Coffee.wmf +0 -0
  134. data/doc/ex/images/Flower_Hat.jpg +0 -0
  135. data/doc/ex/images/Gold_Statue.jpg +0 -0
  136. data/doc/ex/images/Hot_Air_Balloons.jpg +0 -0
  137. data/doc/ex/images/Hot_Air_Balloons_H.jpg +0 -0
  138. data/doc/ex/images/Leaf.miff +0 -0
  139. data/doc/ex/images/No.wmf +0 -0
  140. data/doc/ex/images/Polynesia.jpg +0 -0
  141. data/doc/ex/images/Red_Rocks.jpg +0 -0
  142. data/doc/ex/images/Rocks_On_Beach.miff +0 -0
  143. data/doc/ex/images/Shorts.jpg +0 -0
  144. data/doc/ex/images/Snake.wmf +0 -0
  145. data/doc/ex/images/Violin.jpg +0 -0
  146. data/doc/ex/images/Yellow_Rose.miff +0 -0
  147. data/doc/ex/images/big-duck.gif +0 -0
  148. data/doc/ex/images/duck.gif +0 -0
  149. data/doc/ex/images/duck0.gif +0 -0
  150. data/doc/ex/images/duck1.gif +0 -0
  151. data/doc/ex/images/duck10.gif +0 -0
  152. data/doc/ex/images/duck11.gif +0 -0
  153. data/doc/ex/images/duck12.gif +0 -0
  154. data/doc/ex/images/duck13.gif +0 -0
  155. data/doc/ex/images/duck14.gif +0 -0
  156. data/doc/ex/images/duck15.gif +0 -0
  157. data/doc/ex/images/duck2.gif +0 -0
  158. data/doc/ex/images/duck3.gif +0 -0
  159. data/doc/ex/images/duck4.gif +0 -0
  160. data/doc/ex/images/duck5.gif +0 -0
  161. data/doc/ex/images/duck6.gif +0 -0
  162. data/doc/ex/images/duck7.gif +0 -0
  163. data/doc/ex/images/duck8.gif +0 -0
  164. data/doc/ex/images/duck9.gif +0 -0
  165. data/doc/ex/images/graydient230x6.gif +0 -0
  166. data/doc/ex/images/logo400x83.gif +0 -0
  167. data/doc/ex/images/model.miff +0 -0
  168. data/doc/ex/images/notimplemented.gif +0 -0
  169. data/doc/ex/images/smile.miff +0 -0
  170. data/doc/ex/images/spin.gif +0 -0
  171. data/doc/ex/implode.rb +34 -0
  172. data/doc/ex/level.rb +11 -0
  173. data/doc/ex/level_colors.rb +11 -0
  174. data/doc/ex/line.rb +42 -0
  175. data/doc/ex/line01.rb +23 -0
  176. data/doc/ex/mask.rb +36 -0
  177. data/doc/ex/matte_fill_to_border.rb +40 -0
  178. data/doc/ex/matte_floodfill.rb +33 -0
  179. data/doc/ex/matte_replace.rb +40 -0
  180. data/doc/ex/median_filter.rb +28 -0
  181. data/doc/ex/modulate.rb +11 -0
  182. data/doc/ex/mono.rb +23 -0
  183. data/doc/ex/morph.rb +26 -0
  184. data/doc/ex/mosaic.rb +35 -0
  185. data/doc/ex/motion_blur.rb +11 -0
  186. data/doc/ex/negate.rb +11 -0
  187. data/doc/ex/negate_channel.rb +9 -0
  188. data/doc/ex/nested_rvg.rb +21 -0
  189. data/doc/ex/nonzero.rb +43 -0
  190. data/doc/ex/normalize.rb +11 -0
  191. data/doc/ex/oil_paint.rb +11 -0
  192. data/doc/ex/opacity.rb +37 -0
  193. data/doc/ex/ordered_dither.rb +11 -0
  194. data/doc/ex/path.rb +64 -0
  195. data/doc/ex/pattern1.rb +25 -0
  196. data/doc/ex/pattern2.rb +26 -0
  197. data/doc/ex/polaroid.rb +28 -0
  198. data/doc/ex/polygon.rb +24 -0
  199. data/doc/ex/polygon01.rb +23 -0
  200. data/doc/ex/polyline.rb +23 -0
  201. data/doc/ex/polyline01.rb +23 -0
  202. data/doc/ex/posterize.rb +8 -0
  203. data/doc/ex/preview.rb +9 -0
  204. data/doc/ex/qbezierpath.rb +52 -0
  205. data/doc/ex/quad01.rb +36 -0
  206. data/doc/ex/quantize-m.rb +25 -0
  207. data/doc/ex/radial_blur.rb +9 -0
  208. data/doc/ex/raise.rb +8 -0
  209. data/doc/ex/random_threshold_channel.rb +13 -0
  210. data/doc/ex/rect01.rb +15 -0
  211. data/doc/ex/rect02.rb +22 -0
  212. data/doc/ex/rectangle.rb +35 -0
  213. data/doc/ex/reduce_noise.rb +28 -0
  214. data/doc/ex/remap.rb +12 -0
  215. data/doc/ex/remap_images.rb +21 -0
  216. data/doc/ex/resize_to_fill.rb +10 -0
  217. data/doc/ex/resize_to_fit.rb +10 -0
  218. data/doc/ex/roll.rb +9 -0
  219. data/doc/ex/rotate.rb +45 -0
  220. data/doc/ex/rotate_f.rb +14 -0
  221. data/doc/ex/roundrect.rb +34 -0
  222. data/doc/ex/rubyname.rb +30 -0
  223. data/doc/ex/rvg_clippath.rb +14 -0
  224. data/doc/ex/rvg_linecap.rb +43 -0
  225. data/doc/ex/rvg_linejoin.rb +41 -0
  226. data/doc/ex/rvg_opacity.rb +19 -0
  227. data/doc/ex/rvg_pattern.rb +26 -0
  228. data/doc/ex/rvg_stroke_dasharray.rb +12 -0
  229. data/doc/ex/segment.rb +11 -0
  230. data/doc/ex/sepiatone.rb +8 -0
  231. data/doc/ex/shade.rb +11 -0
  232. data/doc/ex/shadow.rb +31 -0
  233. data/doc/ex/shave.rb +15 -0
  234. data/doc/ex/shear.rb +10 -0
  235. data/doc/ex/sketch.rb +18 -0
  236. data/doc/ex/skewx.rb +52 -0
  237. data/doc/ex/skewy.rb +47 -0
  238. data/doc/ex/smile.rb +125 -0
  239. data/doc/ex/solarize.rb +11 -0
  240. data/doc/ex/sparse_color.rb +55 -0
  241. data/doc/ex/splice.rb +9 -0
  242. data/doc/ex/spread.rb +11 -0
  243. data/doc/ex/stegano.rb +55 -0
  244. data/doc/ex/stroke_dasharray.rb +43 -0
  245. data/doc/ex/stroke_fill.rb +11 -0
  246. data/doc/ex/stroke_linecap.rb +44 -0
  247. data/doc/ex/stroke_linejoin.rb +48 -0
  248. data/doc/ex/stroke_width.rb +49 -0
  249. data/doc/ex/swirl.rb +17 -0
  250. data/doc/ex/text.rb +37 -0
  251. data/doc/ex/text01.rb +17 -0
  252. data/doc/ex/text_align.rb +36 -0
  253. data/doc/ex/text_antialias.rb +38 -0
  254. data/doc/ex/text_styles.rb +21 -0
  255. data/doc/ex/text_undercolor.rb +28 -0
  256. data/doc/ex/texture_fill_to_border.rb +34 -0
  257. data/doc/ex/texture_floodfill.rb +32 -0
  258. data/doc/ex/texturefill.rb +25 -0
  259. data/doc/ex/threshold.rb +13 -0
  260. data/doc/ex/to_blob.rb +14 -0
  261. data/doc/ex/translate.rb +39 -0
  262. data/doc/ex/transparent.rb +38 -0
  263. data/doc/ex/transpose.rb +9 -0
  264. data/doc/ex/transverse.rb +9 -0
  265. data/doc/ex/tref01.rb +25 -0
  266. data/doc/ex/triangle01.rb +16 -0
  267. data/doc/ex/trim.rb +24 -0
  268. data/doc/ex/tspan01.rb +18 -0
  269. data/doc/ex/tspan02.rb +19 -0
  270. data/doc/ex/tspan03.rb +21 -0
  271. data/doc/ex/unsharp_mask.rb +28 -0
  272. data/doc/ex/viewex.rb +35 -0
  273. data/doc/ex/vignette.rb +12 -0
  274. data/doc/ex/watermark.rb +28 -0
  275. data/doc/ex/wave.rb +9 -0
  276. data/doc/ex/wet_floor.rb +59 -0
  277. data/doc/ex/writing_mode01.rb +27 -0
  278. data/doc/ex/writing_mode02.rb +26 -0
  279. data/doc/ilist.html +2056 -0
  280. data/doc/image1.html +4680 -0
  281. data/doc/image2.html +3665 -0
  282. data/doc/image3.html +4522 -0
  283. data/doc/imageattrs.html +1638 -0
  284. data/doc/imusage.html +514 -0
  285. data/doc/index.html +416 -0
  286. data/doc/info.html +1499 -0
  287. data/doc/magick.html +565 -0
  288. data/doc/optequiv.html +2435 -0
  289. data/doc/rvg.html +975 -0
  290. data/doc/rvgclip.html +248 -0
  291. data/doc/rvggroup.html +305 -0
  292. data/doc/rvgimage.html +289 -0
  293. data/doc/rvgpattern.html +475 -0
  294. data/doc/rvgshape.html +406 -0
  295. data/doc/rvgstyle.html +270 -0
  296. data/doc/rvgtext.html +465 -0
  297. data/doc/rvgtspan.html +238 -0
  298. data/doc/rvgtut.html +530 -0
  299. data/doc/rvguse.html +145 -0
  300. data/doc/rvgxform.html +294 -0
  301. data/doc/scripts/doc.js +22 -0
  302. data/doc/scripts/stripeTables.js +23 -0
  303. data/doc/struct.html +1339 -0
  304. data/doc/usage.html +1621 -0
  305. data/examples/constitute.rb +7 -0
  306. data/examples/crop_with_gravity.rb +46 -0
  307. data/examples/demo.rb +324 -0
  308. data/examples/describe.rb +44 -0
  309. data/examples/find_similar_region.rb +34 -0
  310. data/examples/histogram.rb +325 -0
  311. data/examples/identify.rb +187 -0
  312. data/examples/image_opacity.rb +29 -0
  313. data/examples/import_export.rb +31 -0
  314. data/examples/pattern_fill.rb +38 -0
  315. data/examples/rotating_text.rb +45 -0
  316. data/examples/spinner.rb +50 -0
  317. data/examples/thumbnail.rb +65 -0
  318. data/examples/vignette.rb +79 -0
  319. data/ext/RMagick/Makefile +180 -0
  320. data/ext/RMagick/RMagick2.so +0 -0
  321. data/ext/RMagick/extconf.h +119 -0
  322. data/ext/RMagick/extconf.rb +406 -0
  323. data/ext/RMagick/mkmf.log +3022 -0
  324. data/ext/RMagick/rmagick.c +394 -0
  325. data/ext/RMagick/rmagick.h +1307 -0
  326. data/ext/RMagick/rmagick.o +0 -0
  327. data/ext/RMagick/rmdraw.c +1991 -0
  328. data/ext/RMagick/rmdraw.o +0 -0
  329. data/ext/RMagick/rmenum.c +1224 -0
  330. data/ext/RMagick/rmenum.o +0 -0
  331. data/ext/RMagick/rmfill.c +717 -0
  332. data/ext/RMagick/rmfill.o +0 -0
  333. data/ext/RMagick/rmilist.c +1217 -0
  334. data/ext/RMagick/rmilist.o +0 -0
  335. data/ext/RMagick/rmimage.c +15099 -0
  336. data/ext/RMagick/rmimage.o +0 -0
  337. data/ext/RMagick/rminfo.c +2567 -0
  338. data/ext/RMagick/rminfo.o +0 -0
  339. data/ext/RMagick/rmmain.c +1705 -0
  340. data/ext/RMagick/rmmain.o +0 -0
  341. data/ext/RMagick/rmmontage.c +511 -0
  342. data/ext/RMagick/rmmontage.o +0 -0
  343. data/ext/RMagick/rmpixel.c +1103 -0
  344. data/ext/RMagick/rmpixel.o +0 -0
  345. data/ext/RMagick/rmstruct.c +1047 -0
  346. data/ext/RMagick/rmstruct.o +0 -0
  347. data/ext/RMagick/rmutil.c +1730 -0
  348. data/ext/RMagick/rmutil.o +0 -0
  349. data/lib/RMagick.rb +1962 -0
  350. data/lib/rvg/clippath.rb +48 -0
  351. data/lib/rvg/container.rb +131 -0
  352. data/lib/rvg/deep_equal.rb +56 -0
  353. data/lib/rvg/describable.rb +53 -0
  354. data/lib/rvg/embellishable.rb +417 -0
  355. data/lib/rvg/misc.rb +740 -0
  356. data/lib/rvg/paint.rb +55 -0
  357. data/lib/rvg/pathdata.rb +131 -0
  358. data/lib/rvg/rvg.rb +283 -0
  359. data/lib/rvg/stretchable.rb +168 -0
  360. data/lib/rvg/stylable.rb +124 -0
  361. data/lib/rvg/text.rb +187 -0
  362. data/lib/rvg/to_c.rb +103 -0
  363. data/lib/rvg/transformable.rb +133 -0
  364. data/lib/rvg/units.rb +66 -0
  365. data/metaconfig +7 -0
  366. data/post-clean.rb +12 -0
  367. data/post-install.rb +50 -0
  368. data/post-setup.rb +254 -0
  369. data/rmagick.gemspec +20 -0
  370. data/setup.rb +1585 -0
  371. data/test/Draw.rb +121 -0
  372. data/test/Image1.rb +762 -0
  373. data/test/Image2.rb +1308 -0
  374. data/test/Image3.rb +1001 -0
  375. data/test/ImageList1.rb +808 -0
  376. data/test/ImageList2.rb +389 -0
  377. data/test/Image_attributes.rb +682 -0
  378. data/test/Import_Export.rb +116 -0
  379. data/test/Info.rb +349 -0
  380. data/test/Magick.rb +364 -0
  381. data/test/Pixel.rb +120 -0
  382. data/test/Preview.rb +62 -0
  383. data/test/all_basic.rb +39 -0
  384. data/test/cmyk.icm +0 -0
  385. data/test/srgb.icm +0 -0
  386. data/test/test.0 +0 -0
  387. data/uninstall.rb +74 -0
  388. metadata +455 -0
Binary file
@@ -0,0 +1,1103 @@
1
+ /**************************************************************************//**
2
+ * Contains Pixel class methods.
3
+ *
4
+ * Copyright © 2002 - 2009 by Timothy P. Hunter
5
+ *
6
+ * Changes since Nov. 2009 copyright © by Benjamin Thomas and Omer Bar-or
7
+ *
8
+ * @file rmpixel.c
9
+ * @version $Id: rmpixel.c,v 1.7 2009/12/21 10:34:58 baror Exp $
10
+ * @author Tim Hunter
11
+ ******************************************************************************/
12
+
13
+ #include "rmagick.h"
14
+
15
+
16
+
17
+
18
+ static void Color_Name_to_PixelPacket(PixelPacket *, VALUE);
19
+
20
+
21
+
22
+
23
+ /**
24
+ * Free the storage associated with a Pixel object.
25
+ *
26
+ * No Ruby usage (internal function)
27
+ *
28
+ * @param pixel the Pixel object to destroy
29
+ */
30
+ void
31
+ destroy_Pixel(Pixel *pixel)
32
+ {
33
+ xfree(pixel);
34
+ }
35
+
36
+
37
+ /**
38
+ * Get Pixel red attribute.
39
+ *
40
+ * Ruby usage:
41
+ * - @verbatim Pixel#red @endverbatim
42
+ *
43
+ * @param self this object
44
+ * @return the red value
45
+ */
46
+ DEF_ATTR_READER(Pixel, red, int)
47
+
48
+ /**
49
+ * Get Pixel green attribute.
50
+ *
51
+ * Ruby usage:
52
+ * - @verbatim Pixel#green @endverbatim
53
+ *
54
+ * @param self this object
55
+ * @return the green value
56
+ */
57
+ DEF_ATTR_READER(Pixel, green, int)
58
+
59
+ /**
60
+ * Get Pixel blue attribute.
61
+ *
62
+ * Ruby usage:
63
+ * - @verbatim Pixel#blue @endverbatim
64
+ *
65
+ * @param self this object
66
+ * @return the blue value
67
+ */
68
+ DEF_ATTR_READER(Pixel, blue, int)
69
+
70
+ /**
71
+ * Get Pixel opacity attribute.
72
+ *
73
+ * Ruby usage:
74
+ * - @verbatim Pixel#opacity @endverbatim
75
+ *
76
+ * @param self this object
77
+ * @return the opacity value
78
+ */
79
+ DEF_ATTR_READER(Pixel, opacity, int)
80
+
81
+ /**
82
+ * Set Pixel red attribute.
83
+ *
84
+ * Ruby usage:
85
+ * - @verbatim Pixel#red= @endverbatim
86
+ *
87
+ * Notes:
88
+ * - Pixel is Observable. Setters call changed, notify_observers
89
+ * - Setters return their argument values for backward compatibility to when
90
+ * Pixel was a Struct class.
91
+ *
92
+ * @param self this object
93
+ * @param v the red value
94
+ * @return self
95
+ */
96
+ DEF_PIXEL_CHANNEL_WRITER(red)
97
+
98
+ /**
99
+ * Set Pixel green attribute.
100
+ *
101
+ * Ruby usage:
102
+ * - @verbatim Pixel#green= @endverbatim
103
+ *
104
+ * Notes:
105
+ * - Pixel is Observable. Setters call changed, notify_observers
106
+ * - Setters return their argument values for backward compatibility to when
107
+ * Pixel was a Struct class.
108
+ *
109
+ * @param self this object
110
+ * @param v the green value
111
+ * @return self
112
+ */
113
+ DEF_PIXEL_CHANNEL_WRITER(green)
114
+
115
+ /**
116
+ * Set Pixel blue attribute.
117
+ *
118
+ * Ruby usage:
119
+ * - @verbatim Pixel#blue= @endverbatim
120
+ *
121
+ * Notes:
122
+ * - Pixel is Observable. Setters call changed, notify_observers
123
+ * - Setters return their argument values for backward compatibility to when
124
+ * Pixel was a Struct class.
125
+ *
126
+ * @param self this object
127
+ * @param v the blue value
128
+ * @return self
129
+ */
130
+ DEF_PIXEL_CHANNEL_WRITER(blue)
131
+
132
+ /**
133
+ * Set Pixel opacity attribute.
134
+ *
135
+ * Ruby usage:
136
+ * - @verbatim Pixel#opacity= @endverbatim
137
+ *
138
+ * Notes:
139
+ * - Pixel is Observable. Setters call changed, notify_observers
140
+ * - Setters return their argument values for backward compatibility to when
141
+ * Pixel was a Struct class.
142
+ *
143
+ * @param self this object
144
+ * @param v the opacity value
145
+ * @return self
146
+ */
147
+ DEF_PIXEL_CHANNEL_WRITER(opacity)
148
+
149
+
150
+ /*
151
+ * Get/set Pixel CMYK attributes.
152
+ */
153
+ DEF_PIXEL_CMYK_CHANNEL_ACCESSOR(cyan, red)
154
+ DEF_PIXEL_CMYK_CHANNEL_ACCESSOR(magenta, green)
155
+ DEF_PIXEL_CMYK_CHANNEL_ACCESSOR(yellow, blue)
156
+ DEF_PIXEL_CMYK_CHANNEL_ACCESSOR(black, opacity)
157
+
158
+
159
+ /**
160
+ * Raise ArgumentError if the color name cannot be converted to a string via
161
+ * rb_str_to_str.
162
+ *
163
+ * No Ruby usage (internal function)
164
+ *
165
+ * @param arg the argument to convert
166
+ * @return 0
167
+ * @throw ArgumentError
168
+ */
169
+ static VALUE
170
+ color_arg_rescue(VALUE arg)
171
+ {
172
+ rb_raise(rb_eTypeError, "argument must be color name or pixel (%s given)",
173
+ rb_class2name(CLASS_OF(arg)));
174
+ return (VALUE)0;
175
+ }
176
+
177
+
178
+ /**
179
+ * Convert either a String color name or a Magick::Pixel to a PixelPacket.
180
+ *
181
+ * No Ruby usage (internal function)
182
+ *
183
+ * @param pp the PixelPacket to modify
184
+ * @param color the color name or Magick::Pixel
185
+ */
186
+ void
187
+ Color_to_PixelPacket(PixelPacket *pp, VALUE color)
188
+ {
189
+ Pixel *pixel;
190
+
191
+ // Allow color name or Pixel
192
+ if (CLASS_OF(color) == Class_Pixel)
193
+ {
194
+ Data_Get_Struct(color, Pixel, pixel);
195
+ *pp = *pixel;
196
+ }
197
+ else
198
+ {
199
+ // require 'to_str' here instead of just 'to_s'.
200
+ color = rb_rescue(rb_str_to_str, color, color_arg_rescue, color);
201
+ Color_Name_to_PixelPacket(pp, color);
202
+ }
203
+ }
204
+
205
+
206
+ /**
207
+ * Convert a color name to a PixelPacket
208
+ *
209
+ * No Ruby usage (internal function)
210
+ *
211
+ * @param color the PixelPacket to modify
212
+ * @param name_arg the coor name
213
+ * @throw ArgumentError
214
+ */
215
+ static void
216
+ Color_Name_to_PixelPacket(PixelPacket *color, VALUE name_arg)
217
+ {
218
+ MagickBooleanType okay;
219
+ char *name;
220
+ ExceptionInfo exception;
221
+
222
+ GetExceptionInfo(&exception);
223
+ name = StringValuePtr(name_arg);
224
+ okay = QueryColorDatabase(name, color, &exception);
225
+ (void) DestroyExceptionInfo(&exception);
226
+ if (!okay)
227
+ {
228
+ rb_raise(rb_eArgError, "invalid color name %s", name);
229
+ }
230
+ }
231
+
232
+
233
+
234
+ /**
235
+ * Allocate a Pixel object.
236
+ *
237
+ * No Ruby usage (internal function)
238
+ *
239
+ * @param class the Ruby class to use
240
+ * @return a new Magick::Pixel object
241
+ */
242
+ VALUE
243
+ Pixel_alloc(VALUE class)
244
+ {
245
+ Pixel *pixel;
246
+
247
+ pixel = ALLOC(Pixel);
248
+ memset(pixel, '\0', sizeof(Pixel));
249
+ return Data_Wrap_Struct(class, NULL, destroy_Pixel, pixel);
250
+ }
251
+
252
+
253
+ /**
254
+ * "Case equal" operator for Pixel.
255
+ *
256
+ * Ruby usage:
257
+ * - @verbatim Pixel#=== @endverbatim
258
+ *
259
+ * @param self this object
260
+ * @param other the other object
261
+ * @return true or false
262
+ */
263
+
264
+ VALUE
265
+ Pixel_case_eq(VALUE self, VALUE other)
266
+ {
267
+ Pixel *this, *that;
268
+
269
+ if (CLASS_OF(self) == CLASS_OF(other))
270
+ {
271
+ Data_Get_Struct(self, Pixel, this);
272
+ Data_Get_Struct(other, Pixel, that);
273
+ return (this->red == that->red
274
+ && this->blue == that->blue
275
+ && this->green == that->green
276
+ && this->opacity == that->opacity) ? Qtrue : Qfalse;
277
+ }
278
+
279
+ return Qfalse;
280
+ }
281
+
282
+
283
+ /**
284
+ * Clone a Pixel.
285
+ *
286
+ * Ruby usage:
287
+ * - @verbatim Pixel#clone @endverbatim
288
+ *
289
+ * @param self this object
290
+ * @return a clone
291
+ * @see Pixel_dup
292
+ * @see Pixel_init_copy
293
+ */
294
+ VALUE
295
+ Pixel_clone(VALUE self)
296
+ {
297
+ volatile VALUE clone;
298
+
299
+ clone = Pixel_dup(self);
300
+ if (OBJ_FROZEN(self))
301
+ {
302
+ OBJ_FREEZE(clone);
303
+ }
304
+
305
+ return clone;
306
+ }
307
+
308
+
309
+ /**
310
+ * Duplicate a Pixel.
311
+ *
312
+ * Ruby usage:
313
+ * - @verbatim Pixel#dup @endverbatim
314
+ *
315
+ * @param self this object
316
+ * @return a clone
317
+ * @see Pixel_clone
318
+ * @see Pixel_init_copy
319
+ */
320
+ VALUE
321
+ Pixel_dup(VALUE self)
322
+ {
323
+ Pixel *pixel;
324
+ volatile VALUE dup;
325
+
326
+ pixel = ALLOC(Pixel);
327
+ memset(pixel, '\0', sizeof(Pixel));
328
+ dup = Data_Wrap_Struct(CLASS_OF(self), NULL, destroy_Pixel, pixel);
329
+ if (rb_obj_tainted(self))
330
+ {
331
+ (void) rb_obj_taint(dup);
332
+ }
333
+ return rb_funcall(dup, rm_ID_initialize_copy, 1, self);
334
+ }
335
+
336
+
337
+ /**
338
+ * For use with Hash.
339
+ *
340
+ * Ruby usage:
341
+ * - @verbatim Pixel#eql? @endverbatim
342
+ *
343
+ * @param self this object
344
+ * @param other the other object
345
+ * @return true if hash to the same value, otherwise false
346
+ */
347
+ VALUE
348
+ Pixel_eql_q(VALUE self, VALUE other)
349
+ {
350
+ return NUM2INT(Pixel_spaceship(self, other)) == 0 ? Qtrue : Qfalse;
351
+ }
352
+
353
+
354
+ /**
355
+ * Compare pixel values for equality.
356
+ *
357
+ * Ruby usage:
358
+ * - @verbatim Pixel#fcmp(other, fuzz, colorspace) @endverbatim
359
+ *
360
+ * Notes:
361
+ * - Default fuzz is 0.0
362
+ * - Default colorspace is RGBColorspace
363
+ *
364
+ * @param argc number of input arguments
365
+ * @param argv array of input arguments
366
+ * @param self this object
367
+ * @return true if equal, otherwise false
368
+ */
369
+ VALUE
370
+ Pixel_fcmp(int argc, VALUE *argv, VALUE self)
371
+ {
372
+ Image *image;
373
+ Info *info;
374
+
375
+ Pixel *this, *that;
376
+ ColorspaceType colorspace = RGBColorspace;
377
+ double fuzz = 0.0;
378
+ unsigned int equal;
379
+
380
+ switch (argc)
381
+ {
382
+ case 3:
383
+ VALUE_TO_ENUM(argv[2], colorspace, ColorspaceType);
384
+ case 2:
385
+ fuzz = NUM2DBL(argv[1]);
386
+ case 1:
387
+ // Allow 1 argument
388
+ break;
389
+ default:
390
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 1 to 3)", argc);
391
+ break;
392
+ }
393
+
394
+ Data_Get_Struct(self, Pixel, this);
395
+ Data_Get_Struct(argv[0], Pixel, that);
396
+
397
+ // The IsColorSimilar function expects to get the
398
+ // colorspace and fuzz parameters from an Image structure.
399
+
400
+ info = CloneImageInfo(NULL);
401
+ if (!info)
402
+ {
403
+ rb_raise(rb_eNoMemError, "not enough memory to continue");
404
+ }
405
+
406
+ image = AcquireImage(info);
407
+
408
+ // Delete Info now in case we have to raise an exception
409
+ (void) DestroyImageInfo(info);
410
+
411
+ if (!image)
412
+ {
413
+ rb_raise(rb_eNoMemError, "not enough memory to continue");
414
+ }
415
+
416
+ image->colorspace = colorspace;
417
+ image->fuzz = fuzz;
418
+
419
+ equal = IsColorSimilar(image, this, that);
420
+ (void) DestroyImage(image);
421
+
422
+ return equal ? Qtrue : Qfalse;
423
+ }
424
+
425
+
426
+ /**
427
+ * Construct an Magick::Pixel corresponding to the given color name.
428
+ *
429
+ * Ruby usage:
430
+ * - @verbatim Magick::Pixel.from_color(string) @endverbatim
431
+ *
432
+ * Notes:
433
+ * - The "inverse" is Image_to_color, b/c the conversion of a pixel to a
434
+ * color name requires both a color depth and if the opacity value has
435
+ * meaning (i.e. whether image->matte == True or not).
436
+ *
437
+ * @param class the Ruby class to use
438
+ * @param name the color name
439
+ * @return a new Magic::Pixel object
440
+ * @see Image_to_color
441
+ * @see Pixel_to_color
442
+ */
443
+ VALUE
444
+ Pixel_from_color(VALUE class, VALUE name)
445
+ {
446
+ PixelPacket pp;
447
+ ExceptionInfo exception;
448
+ MagickBooleanType okay;
449
+
450
+ class = class; // defeat "never referenced" message from icc
451
+
452
+ GetExceptionInfo(&exception);
453
+ okay = QueryColorDatabase(StringValuePtr(name), &pp, &exception);
454
+ CHECK_EXCEPTION()
455
+ (void) DestroyExceptionInfo(&exception);
456
+
457
+ if (!okay)
458
+ {
459
+ rb_raise(rb_eArgError, "invalid color name: %s", StringValuePtr(name));
460
+ }
461
+
462
+ return Pixel_from_PixelPacket(&pp);
463
+ }
464
+
465
+
466
+ /**
467
+ * Construct an RGB pixel.
468
+ *
469
+ * Ruby usage:
470
+ * - @verbatim Pixel#from_hsla(hue, saturation, lightness) @endverbatim
471
+ * - @verbatim Pixel#from_hsla(hue, saturation, lightness, alpha) @endverbatim
472
+ *
473
+ * Notes:
474
+ * - Default alpha is 1.0
475
+ * - 0 <= hue < 360 OR "0%" <= hue < "100%"
476
+ * - 0 <= saturation <= 255 OR "0%" <= saturation <= "100%"
477
+ * - 0 <= lightness <= 255 OR "0%" <= lightness <= "100%"
478
+ * - 0 <= alpha <= 1 (0 is transparent, 1 is opaque) OR "0%" <= alpha <= "100%"
479
+ * - Replaces brain-dead Pixel_from_HSL.
480
+ *
481
+ * @param argc number of input arguments
482
+ * @param argv array of input arguments
483
+ * @param class the Ruby class to use
484
+ * @return a new Magick::Pixel object
485
+ */
486
+ VALUE
487
+ Pixel_from_hsla(int argc, VALUE *argv, VALUE class)
488
+ {
489
+ double h, s, l, a = 1.0;
490
+ MagickPixelPacket pp;
491
+ ExceptionInfo exception;
492
+ char name[50];
493
+ MagickBooleanType alpha = MagickFalse;
494
+
495
+ class = class; // defeat "unused parameter" message.
496
+
497
+ switch (argc)
498
+ {
499
+ case 4:
500
+ a = rm_percentage(argv[3],1.0);
501
+ alpha = MagickTrue;
502
+ case 3:
503
+ // saturation and lightness are out of 255 in new ImageMagicks and
504
+ // out of 100 in old ImageMagicks. Compromise: always use %.
505
+ l = rm_percentage(argv[2],255.0);
506
+ s = rm_percentage(argv[1],255.0);
507
+ h = rm_percentage(argv[0],360.0);
508
+ break;
509
+ default:
510
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 3 or 4)", argc);
511
+ break;
512
+ }
513
+
514
+ if (alpha && (a < 0.0 || a > 1.0))
515
+ {
516
+ rb_raise(rb_eRangeError, "alpha %g out of range [0.0, 1.0]", a);
517
+ }
518
+ if (l < 0.0 || l > 255.0)
519
+ {
520
+ rb_raise(rb_eRangeError, "lightness %g out of range [0.0, 255.0]", l);
521
+ }
522
+ if (s < 0.0 || s > 255.0)
523
+ {
524
+ rb_raise(rb_eRangeError, "saturation %g out of range [0.0, 255.0]", s);
525
+ }
526
+ if (h < 0.0 || h >= 360.0)
527
+ {
528
+ rb_raise(rb_eRangeError, "hue %g out of range [0.0, 360.0)", h);
529
+ }
530
+
531
+ // Ugly way of checking for change in ImageMagick 6.5.6-5 to see whether
532
+ // saturation/lightness should be out of 255 or out of 100.
533
+ if(MagickLibVersion < 0x656 ||
534
+ (MagickLibVersion == 0x656 && strcmp(MagickLibSubversion,"-5") <= 0) )
535
+ {
536
+ s = s/2.55;
537
+ l = l/2.55;
538
+ }
539
+
540
+ memset(name, 0, sizeof(name));
541
+ if (alpha)
542
+ {
543
+ sprintf(name, "hsla(%-2.1f,%-2.1f,%-2.1f,%-2.1f)", h, s, l, a);
544
+ }
545
+ else
546
+ {
547
+ sprintf(name, "hsl(%-2.1f,%-2.1f,%-2.1f)", h, s, l);
548
+ }
549
+
550
+ GetExceptionInfo(&exception);
551
+
552
+ (void) QueryMagickColor(name, &pp, &exception);
553
+ CHECK_EXCEPTION()
554
+
555
+ (void) DestroyExceptionInfo(&exception);
556
+
557
+ return Pixel_from_MagickPixelPacket(&pp);
558
+ }
559
+
560
+
561
+ /**
562
+ * Construct an RGB pixel from the array [hue, saturation, luminosity].
563
+ *
564
+ * Ruby usage:
565
+ * - @verbatim Pixel.from_HSL @endverbatim
566
+ *
567
+ * @param class the Ruby class to use
568
+ * @param hsl the array
569
+ * @return a new Magick::Pixel object
570
+ * @deprecated This method has been deprecated. Please use Pixel_from_hsla.
571
+ */
572
+ VALUE
573
+ Pixel_from_HSL(VALUE class, VALUE hsl)
574
+ {
575
+ PixelPacket rgb;
576
+ double hue, saturation, luminosity;
577
+
578
+ class = class; // defeat "never referenced" message from icc
579
+ memset(&rgb, 0, sizeof(rgb));
580
+
581
+ hsl = rb_Array(hsl); // Ensure array
582
+ if (RARRAY_LEN(hsl) < 3)
583
+ {
584
+ rb_raise(rb_eArgError, "array argument must have at least 3 elements");
585
+ }
586
+
587
+ hue = NUM2DBL(rb_ary_entry(hsl, 0));
588
+ saturation = NUM2DBL(rb_ary_entry(hsl, 1));
589
+ luminosity = NUM2DBL(rb_ary_entry(hsl, 2));
590
+
591
+ rb_warning("Pixel#from_HSL is deprecated; use from_hsla");
592
+ ConvertHSLToRGB(hue, saturation, luminosity,
593
+ &rgb.red, &rgb.green, &rgb.blue);
594
+ return Pixel_from_PixelPacket(&rgb);
595
+ }
596
+
597
+
598
+ /**
599
+ * Create a Magick::Pixel object from a MagickPixelPacket structure.
600
+ *
601
+ * No Ruby usage (internal function)
602
+ *
603
+ * Notes:
604
+ * - Bypasses normal Pixel.new, Pixel#initialize methods
605
+ *
606
+ * @param pp the MagickPixelPacket
607
+ * @return a new Magick::Pixel object
608
+ */
609
+ VALUE
610
+ Pixel_from_MagickPixelPacket(const MagickPixelPacket *pp)
611
+ {
612
+ Pixel *pixel;
613
+
614
+ pixel = ALLOC(Pixel);
615
+ pixel->red = ROUND_TO_QUANTUM(pp->red);
616
+ pixel->green = ROUND_TO_QUANTUM(pp->green);
617
+ pixel->blue = ROUND_TO_QUANTUM(pp->blue);
618
+ pixel->opacity = ROUND_TO_QUANTUM(pp->opacity);
619
+
620
+ return Data_Wrap_Struct(Class_Pixel, NULL, destroy_Pixel, pixel);
621
+ }
622
+
623
+
624
+ /**
625
+ * Create a Magick::Pixel object from a PixelPacket structure.
626
+ *
627
+ * No Ruby usage (internal function)
628
+ *
629
+ * Notes:
630
+ * - Bypasses normal Pixel.new, Pixel#initialize methods
631
+ *
632
+ * @param pp the PixelPacket
633
+ * @return a new Magick::Pixel object
634
+ */
635
+ VALUE
636
+ Pixel_from_PixelPacket(const PixelPacket *pp)
637
+ {
638
+ Pixel *pixel;
639
+
640
+ pixel = ALLOC(Pixel);
641
+ *pixel = *pp;
642
+ return Data_Wrap_Struct(Class_Pixel, NULL, destroy_Pixel, pixel);
643
+ }
644
+
645
+
646
+ /**
647
+ * Ruby usage:
648
+ * - @verbatim Pixel#hash @endverbatim
649
+ *
650
+ * Notes:
651
+ * - INT2FIX left-shifts 1 bit. Sacrifice 1 bit from the opacity attribute to
652
+ * the FIXNUM_FLAG.
653
+ *
654
+ * @param self this object
655
+ * @return the hash of self
656
+ */
657
+ VALUE
658
+ Pixel_hash(VALUE self)
659
+ {
660
+ Pixel *pixel;
661
+ unsigned int hash;
662
+
663
+ Data_Get_Struct(self, Pixel, pixel);
664
+
665
+ hash = ScaleQuantumToChar(pixel->red) << 24;
666
+ hash += ScaleQuantumToChar(pixel->green) << 16;
667
+ hash += ScaleQuantumToChar(pixel->blue) << 8;
668
+ hash += ScaleQuantumToChar(pixel->opacity);
669
+ hash >>= 1;
670
+
671
+ return INT2FIX(hash);
672
+
673
+ }
674
+
675
+
676
+ /**
677
+ * Initialize clone, dup methods.
678
+ *
679
+ * Ruby usage:
680
+ * - @verbatim Pixel#initialize_copy @endverbatim
681
+ *
682
+ * @param self this object
683
+ * @param orig the original Pixel
684
+ * @return self
685
+ * @see Pixel_clone
686
+ * @see Pixel_dup
687
+ */
688
+ VALUE
689
+ Pixel_init_copy(VALUE self, VALUE orig)
690
+ {
691
+ Pixel *copy, *original;
692
+
693
+ Data_Get_Struct(orig, Pixel, original);
694
+ Data_Get_Struct(self, Pixel, copy);
695
+
696
+ *copy = *original;
697
+
698
+ return self;
699
+ }
700
+
701
+
702
+ /**
703
+ * Ruby usage:
704
+ * - @verbatim Pixel#initialize @endverbatim
705
+ * - @verbatim Pixel#initialize(red) @endverbatim
706
+ * - @verbatim Pixel#initialize(red,green) @endverbatim
707
+ * - @verbatim Pixel#initialize(red,green,blue) @endverbatim
708
+ * - @verbatim Pixel#initialize(red,green,blue,opacity) @endverbatim
709
+ *
710
+ * Notes:
711
+ * - Default red is 0.0
712
+ * - Default green is 0.0
713
+ * - Default blue is 0.0
714
+ * - Default opacity is 0.0
715
+ * - For backward compatibility, arguments may be nil.
716
+ *
717
+ * @param argc number of input arguments
718
+ * @param argv array of input arguments
719
+ * @param self this object
720
+ * @return self
721
+ */
722
+ VALUE
723
+ Pixel_initialize(int argc, VALUE *argv, VALUE self)
724
+ {
725
+ Pixel *pixel;
726
+
727
+ Data_Get_Struct(self, Pixel, pixel);
728
+
729
+ switch(argc)
730
+ {
731
+ case 4:
732
+ if (argv[3] != Qnil)
733
+ {
734
+ pixel->opacity = APP2QUANTUM(argv[3]);
735
+ }
736
+ case 3:
737
+ if (argv[2] != Qnil)
738
+ {
739
+ pixel->blue = APP2QUANTUM(argv[2]);
740
+ }
741
+ case 2:
742
+ if (argv[1] != Qnil)
743
+ {
744
+ pixel->green = APP2QUANTUM(argv[1]);
745
+ }
746
+ case 1:
747
+ if (argv[0] != Qnil)
748
+ {
749
+ pixel->red = APP2QUANTUM(argv[0]);
750
+ }
751
+ case 0:
752
+ break;
753
+ default:
754
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 0 to 4)", argc);
755
+ }
756
+
757
+ return self;
758
+ }
759
+
760
+
761
+ /**
762
+ * Return the "intensity" of a pixel.
763
+ *
764
+ * Ruby usage:
765
+ * - @verbatim Pixel#intensity @endverbatim
766
+ *
767
+ * @param self this object
768
+ * @return the intensity
769
+ */
770
+ VALUE
771
+ Pixel_intensity(VALUE self)
772
+ {
773
+ Pixel *pixel;
774
+ Quantum intensity;
775
+
776
+ Data_Get_Struct(self, Pixel, pixel);
777
+
778
+ intensity = ROUND_TO_QUANTUM((0.299*pixel->red)
779
+ + (0.587*pixel->green)
780
+ + (0.114*pixel->blue));
781
+
782
+ return QUANTUM2NUM((unsigned long) intensity);
783
+ }
784
+
785
+
786
+ /**
787
+ * Support Marshal.dump.
788
+ *
789
+ * Ruby usage:
790
+ * - @verbatim Pixel#marshal_dump @endverbatim
791
+ *
792
+ * @param self this object
793
+ * @return a string representing the dumped pixel
794
+ */
795
+ VALUE
796
+ Pixel_marshal_dump(VALUE self)
797
+ {
798
+ Pixel *pixel;
799
+ volatile VALUE dpixel;
800
+
801
+ Data_Get_Struct(self, Pixel, pixel);
802
+ dpixel = rb_hash_new();
803
+ rb_hash_aset(dpixel, CSTR2SYM("red"), QUANTUM2NUM(pixel->red));
804
+ rb_hash_aset(dpixel, CSTR2SYM("green"), QUANTUM2NUM(pixel->green));
805
+ rb_hash_aset(dpixel, CSTR2SYM("blue"), QUANTUM2NUM(pixel->blue));
806
+ rb_hash_aset(dpixel, CSTR2SYM("opacity"), QUANTUM2NUM(pixel->opacity));
807
+ return dpixel;
808
+ }
809
+
810
+
811
+ /**
812
+ * Support Marshal.load.
813
+ *
814
+ * Ruby usage:
815
+ * - @verbatim Pixel#marshal_load @endverbatim
816
+ *
817
+ * @param self this object
818
+ * @param dpixel the dumped pixel
819
+ * @return self
820
+ */
821
+ VALUE
822
+ Pixel_marshal_load(VALUE self, VALUE dpixel)
823
+ {
824
+ Pixel *pixel;
825
+
826
+ Data_Get_Struct(self, Pixel, pixel);
827
+ pixel->red = NUM2QUANTUM(rb_hash_aref(dpixel, CSTR2SYM("red")));
828
+ pixel->green = NUM2QUANTUM(rb_hash_aref(dpixel, CSTR2SYM("green")));
829
+ pixel->blue = NUM2QUANTUM(rb_hash_aref(dpixel, CSTR2SYM("blue")));
830
+ pixel->opacity = NUM2QUANTUM(rb_hash_aref(dpixel, CSTR2SYM("opacity")));
831
+ return self;
832
+ }
833
+
834
+
835
+ /**
836
+ * Support Comparable mixin.
837
+ *
838
+ * Ruby usage:
839
+ * - @verbatim Pixel#<=> @endverbatim
840
+ *
841
+ * @param self this object
842
+ * @param other the other Pixel
843
+ * @return -1, 0, 1
844
+ */
845
+ VALUE
846
+ Pixel_spaceship(VALUE self, VALUE other)
847
+ {
848
+ Pixel *this, *that;
849
+
850
+ Data_Get_Struct(self, Pixel, this);
851
+ Data_Get_Struct(other, Pixel, that);
852
+
853
+ if (this->red != that->red)
854
+ {
855
+ return INT2NUM((this->red - that->red)/abs(this->red - that->red));
856
+ }
857
+ else if(this->green != that->green)
858
+ {
859
+ return INT2NUM((this->green - that->green)/abs(this->green - that->green));
860
+ }
861
+ else if(this->blue != that->blue)
862
+ {
863
+ return INT2NUM((this->blue - that->blue)/abs(this->blue - that->blue));
864
+ }
865
+ else if(this->opacity != that->opacity)
866
+ {
867
+ return INT2NUM((this->opacity - that->opacity)/abs(this->opacity - that->opacity));
868
+ }
869
+
870
+ // Values are equal, check class.
871
+
872
+ return rb_funcall(CLASS_OF(self), rb_intern("<=>"), 1, CLASS_OF(other));
873
+
874
+ }
875
+
876
+
877
+ /**
878
+ * Return [hue, saturation, lightness, alpha] in the same ranges as
879
+ * Pixel_from_hsla.
880
+ *
881
+ *
882
+ * Ruby usage:
883
+ * - @verbatim Pixel#to_hsla @endverbatim
884
+ *
885
+ * Notes:
886
+ * - Replace brain-dead Pixel_to_HSL.
887
+ *
888
+ * @param self this object
889
+ * @return an array with hsla data
890
+ * @see Pixel_from_hsla
891
+ */
892
+ VALUE
893
+ Pixel_to_hsla(VALUE self)
894
+ {
895
+ double hue, sat, lum, alpha;
896
+ Pixel *pixel;
897
+ volatile VALUE hsla;
898
+
899
+ Data_Get_Struct(self, Pixel, pixel);
900
+
901
+ ConvertRGBToHSL(pixel->red, pixel->green, pixel->blue, &hue, &sat, &lum);
902
+ hue *= 360.0;
903
+ sat *= 255.0;
904
+ lum *= 255.0;
905
+
906
+ if (pixel->opacity == OpaqueOpacity)
907
+ {
908
+ alpha = 1.0;
909
+ }
910
+ else if (pixel->opacity == TransparentOpacity)
911
+ {
912
+ alpha = 0.0;
913
+ }
914
+ else
915
+ {
916
+ alpha = ROUND_TO_QUANTUM(QuantumRange - (pixel->opacity / QuantumRange));
917
+ }
918
+
919
+ hsla = rb_ary_new3(4, rb_float_new(hue), rb_float_new(sat), rb_float_new(lum), rb_float_new(alpha));
920
+ return hsla;
921
+ }
922
+
923
+ /**
924
+ * Convert an RGB pixel to the array [hue, saturation, luminosity].
925
+ *
926
+ * Ruby usage:
927
+ * - @verbatim Pixel#to_HSL @endverbatim
928
+ *
929
+ * @param self this object
930
+ * @return an array with hsl data
931
+ * @deprecated This method has been deprecated. Please use Pixel_to_hsla.
932
+ */
933
+ VALUE
934
+ Pixel_to_HSL(VALUE self)
935
+ {
936
+ Pixel *pixel;
937
+ double hue, saturation, luminosity;
938
+ volatile VALUE hsl;
939
+
940
+ Data_Get_Struct(self, Pixel, pixel);
941
+
942
+ rb_warning("Pixel#to_HSL is deprecated; use to_hsla");
943
+ ConvertRGBToHSL(pixel->red, pixel->green, pixel->blue, &hue, &saturation, &luminosity);
944
+
945
+ hsl = rb_ary_new3(3, rb_float_new(hue), rb_float_new(saturation),
946
+ rb_float_new(luminosity));
947
+
948
+ return hsl;
949
+ }
950
+
951
+
952
+ /**
953
+ * Return the color name corresponding to the pixel values.
954
+ *
955
+ * Ruby usage:
956
+ * - @verbatim Magick::Pixel#to_color @endverbatim
957
+ * - @verbatim Magick::Pixel#to_color(compliance) @endverbatim
958
+ * - @verbatim Magick::Pixel#to_color(compliance, matte) @endverbatim
959
+ * - @verbatim Magick::Pixel#to_color(compliance, matte, depth) @endverbatim
960
+ * - @verbatim Magick::Pixel#to_color(compliance, matte, depth, hex) @endverbatim
961
+ *
962
+ * Notes:
963
+ * - Default compliance is AllCompliance
964
+ * - Default matte is false
965
+ * - Default depth is QuantumDepth
966
+ * - Default hex is false
967
+ * - The conversion respects the value of the 'opacity' field in the Pixel
968
+ *
969
+ * @param argc number of input arguments
970
+ * @param argv array of input arguments
971
+ * @param self this object
972
+ * @return the color name as a String
973
+ */
974
+ VALUE
975
+ Pixel_to_color(int argc, VALUE *argv, VALUE self)
976
+ {
977
+ Info *info;
978
+ Image *image;
979
+ Pixel *pixel;
980
+ MagickPixelPacket mpp;
981
+ MagickBooleanType hex = MagickFalse;
982
+ char name[MaxTextExtent];
983
+ ExceptionInfo exception;
984
+ ComplianceType compliance = AllCompliance;
985
+ unsigned int matte = MagickFalse;
986
+ unsigned int depth = QuantumDepth;
987
+
988
+ switch (argc)
989
+ {
990
+ case 4:
991
+ hex = RTEST(argv[3]);
992
+ case 3:
993
+ depth = NUM2UINT(argv[2]);
994
+
995
+ // Ensure depth is appropriate for the way xMagick was compiled.
996
+ switch (depth)
997
+ {
998
+ case 8:
999
+ #if QuantumDepth == 16 || QuantumDepth == 32
1000
+ case 16:
1001
+ #endif
1002
+ #if QuantumDepth == 32
1003
+ case 32:
1004
+ #endif
1005
+ break;
1006
+ default:
1007
+ rb_raise(rb_eArgError, "invalid depth (%d)", depth);
1008
+ break;
1009
+ }
1010
+ case 2:
1011
+ matte = RTEST(argv[1]);
1012
+ case 1:
1013
+ VALUE_TO_ENUM(argv[0], compliance, ComplianceType);
1014
+ case 0:
1015
+ break;
1016
+ default:
1017
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 0 to 2)", argc);
1018
+ }
1019
+
1020
+ Data_Get_Struct(self, Pixel, pixel);
1021
+
1022
+ info = CloneImageInfo(NULL);
1023
+ image = AcquireImage(info);
1024
+ image->depth = depth;
1025
+ image->matte = matte;
1026
+ (void) DestroyImageInfo(info);
1027
+
1028
+ GetMagickPixelPacket(image, &mpp);
1029
+ rm_set_magick_pixel_packet(pixel, &mpp);
1030
+
1031
+ GetExceptionInfo(&exception);
1032
+
1033
+ #if defined(HAVE_NEW_QUERYMAGICKCOLORNAME)
1034
+ // Support for hex-format color names moved out of QueryMagickColorname
1035
+ // in 6.4.1-9. The 'hex' argument was removed as well.
1036
+ if (hex)
1037
+ {
1038
+ if (compliance == XPMCompliance)
1039
+ {
1040
+ mpp.matte = MagickFalse;
1041
+ mpp.depth = (unsigned long) min(1.0 * image->depth, 16.0);
1042
+ }
1043
+ (void) GetColorTuple(&mpp, MagickTrue, name);
1044
+ }
1045
+ else
1046
+ {
1047
+ (void) QueryMagickColorname(image, &mpp, compliance, name, &exception);
1048
+ }
1049
+ #else
1050
+ (void) QueryMagickColorname(image, &mpp, compliance, hex, name, &exception);
1051
+ #endif
1052
+ (void) DestroyImage(image);
1053
+ CHECK_EXCEPTION()
1054
+ (void) DestroyExceptionInfo(&exception);
1055
+
1056
+ // Always return a string, even if it's ""
1057
+ return rb_str_new2(name);
1058
+ }
1059
+
1060
+
1061
+ /**
1062
+ * Create a string representation of a Magick::Pixel.
1063
+ *
1064
+ * Ruby usage:
1065
+ * - @verbatim Magick::Pixel#to_s @endverbatim
1066
+ *
1067
+ * @param self this object
1068
+ * @return the string
1069
+ */
1070
+ VALUE
1071
+ Pixel_to_s(VALUE self)
1072
+ {
1073
+ Pixel *pixel;
1074
+ char buff[100];
1075
+
1076
+ Data_Get_Struct(self, Pixel, pixel);
1077
+ sprintf(buff, "red=" QuantumFormat ", green=" QuantumFormat ", blue=" QuantumFormat ", opacity=" QuantumFormat
1078
+ , pixel->red, pixel->green, pixel->blue, pixel->opacity);
1079
+ return rb_str_new2(buff);
1080
+ }
1081
+
1082
+
1083
+ /**
1084
+ * Convert a PixelPacket to a MagickPixelPacket.
1085
+ *
1086
+ * No Ruby usage (internal function)
1087
+ *
1088
+ * Notes:
1089
+ * - Same code as the private function SetMagickPixelPacket in ImageMagick.
1090
+ *
1091
+ * @param pixel the pixel
1092
+ * @param pp the MagickPixelPacket to be modified
1093
+ */
1094
+ void
1095
+ rm_set_magick_pixel_packet(Pixel *pixel, MagickPixelPacket *pp)
1096
+ {
1097
+ pp->red = (MagickRealType) pixel->red;
1098
+ pp->green = (MagickRealType) pixel->green;
1099
+ pp->blue = (MagickRealType) pixel->blue;
1100
+ pp->opacity = (MagickRealType) pixel->opacity;
1101
+ pp->index = (MagickRealType) 0.0;
1102
+ }
1103
+