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
@@ -0,0 +1 @@
1
+ For installation instructions see http://rmagick.rubyforge.org/install-osx.html
@@ -0,0 +1,231 @@
1
+ h1. RMagick 0.0.0$ README
2
+
3
+ h2. YY/MM/DD
4
+
5
+ h3. Table of Contents
6
+
7
+ * "Introduction":#intro
8
+ * "Prerequisites":#prereq
9
+ * "Installing RMagick":#install
10
+ * "Configuration Options":#config
11
+ * "Things that can go wrong":#wrong
12
+ * "Upgrading":#upgrade
13
+ * "Uninstalling":#uninstall
14
+ * "More samples":#samples
15
+ * "Reporting Bugs":#bugs
16
+ * "Contact Information":#contact
17
+ * "Credits":#credits
18
+ * "License":#license
19
+
20
+ h2(#intro). Introduction
21
+
22
+ RMagick is an interface between the Ruby programming language and the
23
+ ImageMagick image processing library.
24
+
25
+ h2(#prereq). Prerequisites
26
+
27
+ *O/S* Linux, *BSD, OS X, Windows 2000, XP, Vista, other *nix-like systems.
28
+
29
+ *Ruby* Version 1.8.2 or later. You can get Ruby from "www.ruby-lang.org":http://www.ruby-lang.org.
30
+ The use of versions of Ruby older than 1.8.4 with RMagick is deprecated. Support will be
31
+ removed in a future release.
32
+
33
+ *ImageMagick* Version 6.3.0 or later. You can get ImageMagick from "www.imagemagick.org":http://www.imagemagick.org.
34
+
35
+ h2(#install). Installing RMagick
36
+
37
+ First install ImageMagick. Complete and up-to-date instructions for installing
38
+ ImageMagick on Linux, *BSD, and other *nix-type O/S's are available
39
+ "here":http://rmagick.rubyforge.org/install-linux.html. Use steps 0, 1, and 2.
40
+ Similarly, instructions for installing ImageMagick using MacPorts on OS X
41
+ are available "here":http://rmagick.rubyforge.org/install-osx.html. Use steps
42
+ 1 and 2.
43
+
44
+ This release of RMagick uses Minero Aoki's setup.rb script for installation.
45
+ See the next section for configuration options. Usually you do not need to
46
+ specify any of these options. You can get more information about setup.rb from
47
+ his "web site":<http://i.loveruby.net.
48
+
49
+ I assume you've already decompressed the tarball, or you wouldn't be reading
50
+ this. If you have not decompressed the tarball, do so with one of these commands,
51
+ depending on which tarball you have:
52
+
53
+ <pre>
54
+ tar xvzf RMagick-0.0.0$-tar.gz (gzipped tarball)
55
+ tar xvjf RMagick-0.0.0$-tar.bz2 (bzipped tarball)
56
+ 7z e RMagick-x.y.z.tar.lzma -so | tar xv (7zipped tarball)
57
+ </pre>
58
+
59
+ Change to the RMagick-0.0.0 directory. If you are not using any
60
+ configuration options (usually you don't need to) enter the command
61
+
62
+ <pre>
63
+ ruby setup.rb
64
+ </pre>
65
+
66
+ Note that setup.rb executes all the example programs, so this can take
67
+ some time. This process both builds the example images used in the
68
+ documentation and validates your RMagick installation.
69
+
70
+ After this command completes, make sure you have root privileges (that
71
+ is, login as root or use su or sudo) and enter the command
72
+
73
+ <pre>
74
+ ruby setup.rb install
75
+ </pre>
76
+
77
+ h2(#config). Configuration options
78
+
79
+ Type @ruby setup.rb --help@ to see a list of configuration options. In
80
+ addition to the regular options, there are a few RMagick-specific options:
81
+
82
+ h4. --doc-dir=directory
83
+
84
+ Specify the directory to install the RMagick documentation.
85
+ By default this is $prefix/share/RMagick, where $prefix is the
86
+ prefix specified by --prefix. For example, to install the
87
+ documentation in /Users/me/RMagick, specify:
88
+
89
+ <pre>
90
+ ruby setup.rb --doc-dir=/Users/me/RMagick
91
+ </pre>
92
+
93
+ h4. --allow-example-errors
94
+
95
+ Normally the documentation installation terminates if 5 examples fail.
96
+ If you use this option, the installation does not check for failing
97
+ examples and will always complete. This option is useful if you're
98
+ having trouble installing RMagick and you want to see all the failing examples.
99
+
100
+ h4. -- disable-htmldoc
101
+
102
+ By default the install process runs all the RMagick example programs and
103
+ generates HTML versions of all the examples. This option causes the
104
+ install process to skip this step. No install verification will take
105
+ place and no documentation will be installed.
106
+
107
+ h2(#wrong). Things that can go wrong
108
+
109
+ The "RMagick installation FAQ":http://rmagick.rubyforge.org/install-faq.html
110
+ has answers to the most commonly reported problems.
111
+
112
+ h4. Can't install RMagick. Can't find libMagick or one of the dependent libraries. Check the mkmf.log file for more detailed information.
113
+
114
+ Typically this message means that one or more of the libraries that ImageMagick
115
+ depends on hasn't been installed. Examine the mkmf.log file in the ext/RMagick
116
+ subdirectory of the installation directory for any error messages. These messages
117
+ typically contain enough additional information for you to be able to diagnose
118
+ the problem. Also see "this FAQ":http://rmagick.rubyforge.org/install-faq.html#libmagick.
119
+
120
+ h4. Cannot open shared object file
121
+
122
+ If you get a message like this:
123
+
124
+ <pre>
125
+ $DIR/RMagick.rb:11:in `require': libMagick.so.0:
126
+ cannot open shared object file: No such file or directory -
127
+ $DIR/RMagick2.so (LoadError)
128
+ </pre>
129
+
130
+ you probably do not have the directory in which the ImageMagick library
131
+ is installed in your load path. An easy way to fix this is to define
132
+ the directory in the LD_LIBRARY_PATH environment variable. For
133
+ example, suppose you installed the ImageMagick library libMagick.so in
134
+ /usr/local/lib. (By default this is where it is installed.) Create the
135
+ LD_LIBRARY_PATH variable like this:
136
+
137
+ <pre>
138
+ export LD_LIBRARY_PATH=/usr/local/lib
139
+ </pre>
140
+
141
+ On Linux, see @ld(1)@ and @ld.so(8)@ for more information. On other operating
142
+ systems, see the documentation for the dynamic loading facility.
143
+
144
+ h4. No such file or directory - "/tmp/rmagick6872.6"
145
+
146
+ When setup.rb is running the examples, if you get a message like this:
147
+
148
+ <pre>
149
+ hook /home/me/src/RMagick-0.0.0/./post-setup.rb failed:
150
+ No such file or directory - "/tmp/rmagick6872.6"
151
+ </pre>
152
+
153
+ you probably do not have a temporary directory environment variable set. Set
154
+ the TMPDIR environment variable to your temporary directory. For example:
155
+
156
+ <pre>
157
+ export TMPDIR=/home/me/tmp
158
+ </pre>
159
+
160
+
161
+ h2(#upgrade). Upgrading
162
+
163
+ If you upgrade to a newer release of ImageMagick, make sure you're using a
164
+ release of RMagick that supports that release. It's safe to install a new
165
+ release of RMagick over an earlier release.
166
+
167
+ h2(#uninstall). Uninstalling
168
+
169
+ The uninstall.rb script will uninstall RMagick completely. Make sure you
170
+ have administrator priviledges. Then run this command:
171
+
172
+ <pre>
173
+ ruby uninstall.rb
174
+ </pre>
175
+
176
+ h2(#samples). More samples
177
+
178
+ You can find more sample RMagick programs in the /example directory.
179
+ These programs are not installed in the RMagick documentation tree.
180
+
181
+ h2(#bugs). Reporting bugs
182
+
183
+ Please report bugs in RMagick, its documentation, or its installation
184
+ programs to me via the bug tracker on the "RMagick project page":http://rubyforge.org/projects/rmagick.
185
+ However, I can't help with Ruby installation and configuration or ImageMagick
186
+ installation and configuration. Information about reporting problems and
187
+ getting help for ImageMagick is available at the "ImageMagick web site":http://www.imagemagick.org
188
+ or the "ImageMagick Forum":http://www.imagemagick.org/discourse-server.
189
+
190
+ h2(#contact). Contact Information
191
+
192
+ *Author:* Tim Hunter, Omer Bar-or, Benjamin Thomas
193
+
194
+ *Email:* "rmagick@rubyforge.org":mailto:rmagick@rubyforge.org
195
+
196
+ *Web site:* "http://rmagick.rubyforge.org":http://rmagick.rubyforge.org
197
+
198
+ h2(#credits). Credits
199
+
200
+ Thanks to "ImageMagick Studio LLC":http://www.imagemagick.org for ImageMagick
201
+ and for hosting the RMagick documentation.
202
+
203
+ h2(#license). License
204
+
205
+ <pre>
206
+ Copyright &copy; 2002-2009 by Timothy P. Hunter
207
+
208
+ Changes since Nov. 2009 copyright &copy; by Benjamin Thomas and Omer Bar-or
209
+
210
+ Permission is hereby granted, free of charge, to any person obtaining a
211
+ copy of this software and associated documentation files (the "Software"),
212
+ to deal in the Software without restriction, including without limitation
213
+ the rights to use, copy, modify, merge, publish, distribute, sublicense,
214
+ and/or sell copies of the Software, and to permit persons to whom the
215
+ Software is furnished to do so, subject to the following conditions:
216
+
217
+ The above copyright notice and this permission notice shall be included in
218
+ all copies or substantial portions of the Software.
219
+
220
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
221
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
222
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
223
+ THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
224
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
225
+ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
226
+ DEALINGS IN THE SOFTWARE.
227
+ </pre>
228
+
229
+ <hr>
230
+ This file is marked up using "Textile":http://hobix.com/textile/ and converted
231
+ to HTML with "RedCloth":http://whytheluckystiff.net/ruby/redcloth/.
@@ -0,0 +1,215 @@
1
+
2
+ # Build the tar.gz, tar.bz2, and .gem files for an RMagick Release
3
+ # Expects the CVS tag for release RMagick x.y.z to be in the form RMagick_x-y-z.
4
+ # To use: cd to $HOME
5
+ # run: rake -f path/to/build_tarball.rake clean
6
+ # rake -f path/to/build_tarball.rake release=tag beta=whatever
7
+ #
8
+ # Specify the release as release=RMagick_x-y-z or nothing if release=HEAD
9
+ # Specify a beta Release as beta=beta1
10
+
11
+ require 'rubygems'
12
+ require 'redcloth'
13
+ require 'find'
14
+ require 'fileutils'
15
+ include FileUtils
16
+
17
+
18
+ CVSSERVER = ":ext:rmagick@rubyforge.org/var/cvs/rmagick"
19
+
20
+
21
+ # CVS_Tag is the CVS tag for this release. Dist_Directory is CVS_Tag,
22
+ # modified for use as a directory name.
23
+ if ENV.include?("release")
24
+ CVS_Tag = ENV["release"]
25
+ Dist_Directory = CVS_Tag.tr('_-','-.')
26
+ else
27
+ CVS_Tag = "HEAD"
28
+ Dist_Directory = "RMagick-0.0.0"
29
+ end
30
+
31
+
32
+ # RMagick_Version is just X.Y.Z
33
+ RMagick_Version = Dist_Directory.sub(/RMagick-/, "")
34
+
35
+ # RMagick_Version2 is X.Y.Z + "-beta1" if beta=beta1
36
+ RMagick_Version2 = RMagick_Version + (ENV.include?("beta") ? "-" + ENV["beta"] : "")
37
+
38
+ # Release is RMagick-X.Y.Z, plus "-beta1" if beta=beta1
39
+ Release = Dist_Directory + (ENV.include?("beta") ? "-" + ENV["beta"] : "")
40
+
41
+ README = "README.html"
42
+ MANIFEST = "ext/RMagick/MANIFEST"
43
+
44
+
45
+
46
+
47
+ # Change the version number placeholders in a file.
48
+ # Returns an array of lines from the file.
49
+ def reversion(name)
50
+ now = Time.new
51
+ now = now.strftime("%m/%d/%y")
52
+
53
+ lines = File.readlines name
54
+ lines.each do |line|
55
+ line.gsub!(%r{0\.0\.0\$}, RMagick_Version2)
56
+ line.gsub!(%r{0\.0\.0}, RMagick_Version)
57
+ line.gsub!(%r{YY/MM/DD}, now)
58
+ end
59
+ lines
60
+ end
61
+
62
+
63
+
64
+
65
+ # Rewrite a file containing embedded version number placeholders.
66
+ def reversion_file(name)
67
+ lines = reversion(name)
68
+ tmp_name = name + "_tmp"
69
+ mv name, tmp_name
70
+ begin
71
+ File.open(name, "w") { |f| lines.each { |line| f.write line } }
72
+ rescue
73
+ mv tmp_name, name
74
+ ensure
75
+ rm tmp_name
76
+ end
77
+ end
78
+
79
+
80
+
81
+
82
+ task :extconf do
83
+ Dir.chdir(Dist_Directory) { reversion_file "ext/RMagick/extconf.rb" }
84
+ end
85
+
86
+
87
+
88
+
89
+ task :gemspec do
90
+ Dir.chdir(Dist_Directory) { reversion_file "rmagick.gemspec" }
91
+ end
92
+
93
+
94
+
95
+
96
+ task "README.txt" do
97
+ Dir.chdir Dist_Directory do
98
+ reversion_file "README.rc"
99
+ body = File.readlines "README.rc"
100
+ body = RedCloth.new(body.join).to_html + "\n"
101
+ File.open("README.txt", "w") { |f| f.write body }
102
+ end
103
+ end
104
+
105
+
106
+
107
+
108
+ task README => "README.txt" do
109
+ puts "writing #{README}"
110
+ Dir.chdir Dist_Directory do
111
+ File.open(README, "w") do |html|
112
+ html.write <<END_HTML_HEAD
113
+ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
114
+ <html>
115
+ <head>
116
+ <title>RMagick #{RMagick_Version2} README</title>
117
+ <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
118
+ <meta name="GENERATOR" content="RedCloth">
119
+ </head>
120
+ <body>
121
+ END_HTML_HEAD
122
+ html.write File.readlines("README.txt")
123
+ html.write <<END_HTML_TAIL
124
+ </body>
125
+ </html>
126
+ END_HTML_TAIL
127
+ end
128
+ end
129
+ end
130
+
131
+
132
+
133
+
134
+ task :doc do
135
+ Dir.chdir(File.join(Dist_Directory, "doc")) do
136
+ FileList["*.html"].each { |d| reversion_file(d) }
137
+ end
138
+ end
139
+
140
+
141
+
142
+
143
+ # Remove files we don't want in the tarball.
144
+ # Ensure files are not executable. (ref: bug #10080)
145
+ task :fix_files do
146
+ Dir.chdir Dist_Directory do
147
+ rm_rf "test", :verbose => true
148
+ rm "lib/rvg/to_c.rb", :verbose => true
149
+ rm "README.rc", :verbose => true
150
+ rm "README.txt", :verbose => true
151
+ chmod 0644, FileList["doc/*.html", "doc/ex/*.rb", "doc/ex/images/*", "examples/*.rb"]
152
+ end
153
+ end
154
+
155
+
156
+
157
+
158
+ task :manifest do
159
+ now = Time.new
160
+ now = now.strftime("%H:%M:%S %m/%d/%y")
161
+ puts "generating #{MANIFEST}"
162
+
163
+ Dir.chdir Dist_Directory do
164
+ File.open(MANIFEST, "w") do |f|
165
+ f.puts "MANIFEST for #{Release} - #{now}\n\n"
166
+ Find.find('.') do |name|
167
+ next if File.directory? name
168
+ f.puts name[2..-1] # remove leading "./"
169
+ end
170
+ end
171
+ end
172
+ end
173
+
174
+
175
+
176
+
177
+ task :export do
178
+ sh "cvs -d#{CVSSERVER} export -r #{CVS_Tag} -d #{Dist_Directory} RMagick"
179
+ end
180
+
181
+
182
+
183
+
184
+ task :collateral => [README, :gemspec, :extconf, :doc]
185
+
186
+ GEM = Dist_Directory.downcase + ".gem"
187
+
188
+ task :default => [:export, :collateral, :fix_files, :manifest] do
189
+ sh "tar czf #{Release}.tar.gz #{Dist_Directory}"
190
+ sh "tar cjf #{Release}.tar.bz2 #{Dist_Directory}"
191
+ sh "tar c #{Release} | 7z a -t7z -m0=lzma -mx=9 -mfb=64 -ms=on -si#{Release}.tar #{Release}.tar.lzma"
192
+
193
+ # Extract with
194
+ # 7z e RMagick-x.y.z.tar.lzma -so | tar xv
195
+ #sh "tar cf #{Release}.tar #{Dist_Directory}"
196
+ #sh "7z a -t7z -m0=lzma -mx=9 -mfb=64 -md=32m -ms=on #{Release}.tar.lzma #{Release}.tar"
197
+ #rm_rf Release+".tar", :verbose => true
198
+
199
+ Dir.chdir(Dist_Directory) do
200
+ sh "gem build rmagick.gemspec"
201
+ mv GEM, "../", :verbose => true
202
+ end
203
+ end
204
+
205
+
206
+
207
+
208
+ task :clean do
209
+ rm_rf Dist_Directory, :verbose => true
210
+ rm_rf Release+".tar.gz", :verbose => true
211
+ rm_rf Release+".tar.bz2", :verbose => true
212
+ rm_rf Release+".tar.lzma", :verbose => true
213
+ rm_rf GEM, :verbose => true
214
+ end
215
+
@@ -0,0 +1,287 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3
+
4
+ <html xmlns="http://www.w3.org/1999/xhtml">
5
+ <head>
6
+ <meta name="generator" content=
7
+ "HTML Tidy for Linux/x86 (vers 1 September 2005), see www.w3.org" />
8
+
9
+ <title>RMagick 0.0.0: Common Tasks</title>
10
+ <meta http-equiv="Content-Type" content=
11
+ "text/html; charset=us-ascii" />
12
+ <meta name="GENERATOR" content="Quanta Plus" />
13
+ <meta name="Copyright" content=
14
+ "Copyright (C) 2006 by Timothy P. Hunter" />
15
+ <link rel="stylesheet" type="text/css" href="css/doc.css" />
16
+ <script type="text/javascript" src="scripts/doc.js">
17
+ </script>
18
+ <style type="text/css">
19
+ /*<![CDATA[*/
20
+
21
+ /* Styles local to this page. */
22
+ #drop_shadow {
23
+ margin-left: auto;
24
+ margin-right: auto;
25
+ width: 250px;
26
+ }
27
+
28
+
29
+ /*]]>*/
30
+ </style>
31
+ </head>
32
+
33
+ <body>
34
+ <h6 id="header">RMagick 0.0.0 User's Guide and Reference</h6>
35
+
36
+ <div class="nav">
37
+ &laquo;&nbsp;<a href="optequiv.html">Prev</a> | <a href=
38
+ "index.html">Contents</a> | <a href=
39
+ "magick.html">Next</a>&nbsp;&raquo;
40
+ </div>
41
+
42
+ <h1>Common Tasks</h1>
43
+
44
+ <div id="toc">
45
+ <h2>Table of Contents</h2>
46
+
47
+ <ul style="margin-left: 15px; padding-top: 1em;">
48
+ <li><a href="#info">Getting information about an
49
+ image</a></li>
50
+
51
+ <li><a href="#convert">Converting an image to another
52
+ format</a></li>
53
+
54
+ <li><a href="#thumb">Making thumbnails</a></li>
55
+
56
+ <li><a href="#resizing">Resizing to a maximum (or minimum)
57
+ size</a></li>
58
+
59
+ <li><a href="#blob">Writing to or reading from a string
60
+ instead of a file</a></li>
61
+
62
+ <li><a href="#gray">Converting a color image to
63
+ grayscale</a></li>
64
+
65
+ <li><a href="#compressing">Compressing image files</a></li>
66
+
67
+ <li><a href="#shadow">Making a drop shadow</a></li>
68
+ </ul>
69
+ </div>
70
+
71
+ <h2 id="info">Getting information about an image</h2>
72
+
73
+ <p>One of the most fundamental operations on an image is simply
74
+ getting basic information about the image. RMagick assigns dozens
75
+ of <a href="imageattrs.html">attributes</a> to an image. All you
76
+ have to do is read the image and then call the attribute methods.
77
+ Here's a Ruby program that takes image filenames from the command
78
+ line and then prints a variety of information about each image to
79
+ the terminal.</p>
80
+ <pre class="example">
81
+ require 'RMagick'
82
+ ARGV.each { |file|
83
+ puts file
84
+ img = Magick::Image::read(file).first
85
+ puts " Format: #{img.format}"
86
+ puts " Geometry: #{img.columns}x#{img.rows}"
87
+ puts " Class: " + case img.class_type
88
+ when Magick::DirectClass
89
+ "DirectClass"
90
+ when Magick::PseudoClass
91
+ "PseudoClass"
92
+ end
93
+ puts " Depth: #{img.depth} bits-per-pixel"
94
+ puts " Colors: #{img.number_colors}"
95
+ puts " Filesize: #{img.filesize}"
96
+ puts " Resolution: #{img.x_resolution.to_i}x#{img.y_resolution.to_i} "+
97
+ "pixels/#{img.units == Magick::PixelsPerInchResolution ?
98
+ "inch" : "centimeter"}"
99
+ if img.properties.length &gt; 0
100
+ puts " Properties:"
101
+ img.properties { |name,value|
102
+ puts %Q| #{name} = "#{value}"|
103
+ }
104
+ end
105
+ }
106
+ </pre>
107
+
108
+ <h2 id="convert">Converting an image to another format</h2>
109
+
110
+ <p>Converting an image to another format is as simple as writing
111
+ the image to a file. ImageMagick uses the output filename
112
+ suffix (".jpg" for JPEG, ".gif" for GIF, for example) or prefix
113
+ ("ps:" for PostScript, for example) to determine the format of
114
+ the output image.</p>
115
+
116
+ <h2 id="thumb">Making thumbnails</h2>
117
+
118
+ <p>RMagick gives you four different methods for resizing an
119
+ image: <a href="image3.html#resize"><code>resize</code></a>,
120
+ <a href="image3.html#sample"><code>sample</code></a>, <a href=
121
+ "image3.html#scale"><code>scale</code></a>, and <a href=
122
+ "image3.html#thumbnail"><code>thumbnail</code></a>. All four are
123
+ equally easy to use. Specify the number of columns and rows you
124
+ want the thumbnail to have, like this:</p>
125
+ <pre class="example">
126
+ img = Image.new "bigimage.gif"
127
+ thumb = img.scale(125, 125)
128
+ thumb.write "thumb.gif"
129
+ </pre>
130
+
131
+ <p>Alternatively, just pass a single <code>Float</code> argument
132
+ that represents the change in size. For example, to
133
+ proportionally reduce the size of an image to 25% of its original
134
+ size, do this:</p>
135
+ <pre class="example">
136
+ img = Image.new "bigimage.gif"
137
+ thumb = img.scale(0.25)
138
+ thumb.write "thumb.gif"
139
+ </pre>
140
+
141
+ <p>The <code>resize</code> method gives you more control by
142
+ allowing you to specify a <a href=
143
+ "constants.html#FilterType">filter</a> to use when scaling the
144
+ image. Some filters produce a better-looking thumbnail at the
145
+ expense of extra processing time. You can also use a
146
+ <code>blur</code> argument, which specifies how much blurriness
147
+ or sharpness the resize method should introduce.</p>
148
+
149
+ <p>The <code>sample</code> method, unlike the other two, does not
150
+ do any color interpolation when resizing.</p>
151
+
152
+ <p>The <code>thumbnail</code> method is faster than
153
+ <code>resize</code> if the thumbnail is less than 10% of the size
154
+ of the original image.</p>
155
+
156
+ <h3>flickr-style thumbnails</h3>
157
+
158
+ <p><a href="http://www.flickr.com">flickr</a> thumbnails are 75
159
+ pixels wide and 75 pixels tall. If the original image isn't
160
+ square, the thumbnail is cropped in its larger dimension so that
161
+ the image isn't distorted. You can get make this kind of
162
+ thumbnail with the <a href=
163
+ "image3.html#resize_to_fill">resize_to_fill</a> method.</p>
164
+ <pre class="example">
165
+ thumb = img.resize_to_fill(75, 75)
166
+ </pre>
167
+
168
+ <h2 id="resizing">Resizing to a maximum (or minimum) size</h2>
169
+
170
+ <p>Say you need to make all your thumbnails no bigger than 64x64
171
+ but with the same aspect ratio as the original. Or, you don't
172
+ want to resize the image if it's already smaller than 64x64. The
173
+ <a href=
174
+ "image1.html#change_geometry"><code>change_geometry</code></a>
175
+ method can help.</p>
176
+
177
+ <p>The <code>change_geometry</code> method accepts an
178
+ ImageMagick <a href="imusage.html#geometry">geometry string</a>
179
+ argument and a block. The geometry string specifies how to change
180
+ the image's size: one or two numbers to specify the new size and
181
+ optional flags to describe any constraints. The
182
+ <code>change_geometry</code> method parses the geometry string
183
+ and computes new width and height values. Then it calls the
184
+ block, passing the values it computed.</p>
185
+
186
+ <p>Within the block you can do whatever you want with the new
187
+ values. Typically you'll call one of the resize methods mentioned
188
+ in the previous section and make the resized image the return
189
+ value from the block. The <code>change_geometry</code> method
190
+ then returns that value to its caller.</p>
191
+
192
+ <h3>Simple thumbnails</h3>
193
+
194
+ <p>If you just want to make sure your thumbnail is no bigger than
195
+ a certain width and height, use the <a href=
196
+ "image3.html#resize_to_fit">resize_to_fit</a> method.</p>
197
+ <pre class="example">
198
+ thumb = img.resize_to_fit(75, 75)
199
+ </pre>
200
+
201
+ <h2><a id="blob" name="blob">Writing to or reading from a string
202
+ instead of a file</a></h2>
203
+
204
+ <p>Use the <a href="image1.html#from_blob">Image.from_blob</a>
205
+ method to construct an Image object from a string. Use the
206
+ <a href="image3.html#to_blob">Image#to_blob</a> method to convert
207
+ an image to a string. A blob is simply an in-memory version of an
208
+ image file. That is, you could use <code>File.read</code> to read
209
+ an JPEG file into a string, then create an image by using that
210
+ string as an argument to <code>from_blob</code>. Similarly, if
211
+ you create a string version of an image with
212
+ <code>to_blob</code>, then write the string to a file, any image
213
+ viewer will be able to display it just as if you had written the
214
+ image directly to a file. Blobs are very useful in web
215
+ applications when you want to modify an image and then stream it
216
+ back to the client.</p>
217
+
218
+ <p>Use <a href=
219
+ "image2.html#import_pixels">Image#import_pixels</a> to load pixel
220
+ data from a string buffer into an image. The pixel data must be
221
+ in scanline order, right-to-left and top-to-bottom. The data can
222
+ be packed as 8-bit bytes, 16-bit halfwords, 32-bit fullwords, or
223
+ as C floats or doubles. The reciprocal method is <a href=
224
+ "image3.html#export_pixels_to_str">Image#export_pixels_to_str</a>.</p>
225
+
226
+ <h2 id="gray">Converting a color image to grayscale</h2>
227
+
228
+ <p>Use the <a href=
229
+ "image3.html#quantize"><code>quantize</code></a> method with the
230
+ <a href=
231
+ "constants.html#ColorspaceType">Magick::GRAYColorspace</a>
232
+ argument. If you want real "grayscale," quantize the image to 256
233
+ colors. If you want to convert a color image to black-and-white,
234
+ use 2 colors. (See the <code>demo.rb</code> example.)</p>
235
+
236
+ <h2 id="compressing">Compressing image files</h2>
237
+
238
+ <p>Many image formats, including JPEG, PDF, and BMP, support
239
+ compressed image files. The type of compression used depends on
240
+ the format. Specify the compression type by assigning a <a href=
241
+ "constants.html#CompressionType">CompressionType</a> value to the
242
+ <a href="info.html#compression">compression</a> optional argument
243
+ to the <a href="image3.html#write">write</a> method.</p>
244
+
245
+ <p>The JPEGCompression and ZipCompression types support multiple
246
+ levels of compression. Use the <a href=
247
+ "info.html#quality">quality</a> optional argument to the
248
+ <code>write</code> method. The quality attribute is a number
249
+ between 0 and 100, with 100 representing the least compression.
250
+ When you compress an image using JPEGCompression, more
251
+ compression usually results in a lower-quality image. When you
252
+ compress an image using ZipCompression, more compression usually
253
+ takes longer.</p>
254
+
255
+ <p>For more information, see the ImageMagick documentation for
256
+ the <code>-quality</code> option to the utility commands.</p>
257
+ <pre class="example">
258
+ img.write("myimage.jpg") { self.quality = 50 }
259
+ </pre>
260
+
261
+ <h2 id="shadow">Making a drop shadow</h2>
262
+
263
+ <p>Here's one way to make a drop shadow behind text. Make the
264
+ shadow first by drawing the text in a light gray color. Position
265
+ the text slightly to the right and down from where the real text
266
+ will be. Then use the <a href=
267
+ "image1.html#blur_image"><code>blur_image</code></a> method to
268
+ make the shadow by blurring the text. Finally, draw the text
269
+ again in whatever color you want. <em>(Click the image to see the
270
+ Ruby program that created it.)</em></p>
271
+
272
+ <div id="drop_shadow">
273
+ <a href="javascript:popup('drop_shadow.rb.html')"><img src=
274
+ "ex/drop_shadow.gif" title="Click to see the example script"
275
+ alt="drop shadow example" /></a>
276
+ </div>
277
+ <hr />
278
+
279
+ <p class="spacer"></p>
280
+
281
+ <div class="nav">
282
+ &laquo; <a href="optequiv.html">Prev</a> | <a href=
283
+ "index.html">Contents</a> | <a href="magick.html">Next</a>
284
+ &raquo;
285
+ </div>
286
+ </body>
287
+ </html>