rdp-rmagick 0.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/ChangeLog +769 -0
- data/Doxyfile +1514 -0
- data/README-Mac-OSX.txt +1 -0
- data/README.md +231 -0
- data/build_tarball.rake +215 -0
- data/doc/comtasks.html +287 -0
- data/doc/constants.html +1581 -0
- data/doc/css/doc.css +299 -0
- data/doc/css/popup.css +34 -0
- data/doc/css/ref.css +67 -0
- data/doc/draw.html +3269 -0
- data/doc/ex/InitialCoords.rb +23 -0
- data/doc/ex/NewCoordSys.rb +32 -0
- data/doc/ex/OrigCoordSys.rb +18 -0
- data/doc/ex/PreserveAspectRatio.rb +205 -0
- data/doc/ex/RotateScale.rb +37 -0
- data/doc/ex/Skew.rb +38 -0
- data/doc/ex/Use01.rb +16 -0
- data/doc/ex/Use02.rb +21 -0
- data/doc/ex/Use03.rb +16 -0
- data/doc/ex/ViewBox.rb +33 -0
- data/doc/ex/adaptive_threshold.rb +10 -0
- data/doc/ex/add_noise.rb +17 -0
- data/doc/ex/affine.rb +48 -0
- data/doc/ex/affine_transform.rb +20 -0
- data/doc/ex/arc.rb +49 -0
- data/doc/ex/arcpath.rb +33 -0
- data/doc/ex/arcs01.rb +28 -0
- data/doc/ex/arcs02.rb +61 -0
- data/doc/ex/average.rb +15 -0
- data/doc/ex/axes.rb +64 -0
- data/doc/ex/baseline_shift01.rb +18 -0
- data/doc/ex/bilevel_channel.rb +9 -0
- data/doc/ex/blur_image.rb +12 -0
- data/doc/ex/border.rb +10 -0
- data/doc/ex/bounding_box.rb +44 -0
- data/doc/ex/cbezier1.rb +42 -0
- data/doc/ex/cbezier2.rb +42 -0
- data/doc/ex/cbezier3.rb +42 -0
- data/doc/ex/cbezier4.rb +43 -0
- data/doc/ex/cbezier5.rb +43 -0
- data/doc/ex/cbezier6.rb +53 -0
- data/doc/ex/channel.rb +26 -0
- data/doc/ex/charcoal.rb +12 -0
- data/doc/ex/chop.rb +29 -0
- data/doc/ex/circle.rb +33 -0
- data/doc/ex/circle01.rb +17 -0
- data/doc/ex/clip_path.rb +60 -0
- data/doc/ex/coalesce.rb +60 -0
- data/doc/ex/color_fill_to_border.rb +29 -0
- data/doc/ex/color_floodfill.rb +28 -0
- data/doc/ex/color_histogram.rb +48 -0
- data/doc/ex/color_reset.rb +11 -0
- data/doc/ex/colorize.rb +16 -0
- data/doc/ex/colors.rb +64 -0
- data/doc/ex/compose_mask.rb +23 -0
- data/doc/ex/composite.rb +135 -0
- data/doc/ex/composite_layers.rb +53 -0
- data/doc/ex/composite_tiled.rb +23 -0
- data/doc/ex/contrast.rb +36 -0
- data/doc/ex/crop.rb +31 -0
- data/doc/ex/crop_with_gravity.rb +46 -0
- data/doc/ex/cubic01.rb +45 -0
- data/doc/ex/cubic02.rb +94 -0
- data/doc/ex/cycle_colormap.rb +21 -0
- data/doc/ex/dissolve.rb +13 -0
- data/doc/ex/drawcomp.rb +42 -0
- data/doc/ex/drop_shadow.rb +60 -0
- data/doc/ex/edge.rb +11 -0
- data/doc/ex/ellipse.rb +45 -0
- data/doc/ex/ellipse01.rb +22 -0
- data/doc/ex/emboss.rb +11 -0
- data/doc/ex/enhance.rb +28 -0
- data/doc/ex/equalize.rb +11 -0
- data/doc/ex/evenodd.rb +43 -0
- data/doc/ex/fill_pattern.rb +26 -0
- data/doc/ex/flatten_images.rb +36 -0
- data/doc/ex/flip.rb +11 -0
- data/doc/ex/flop.rb +11 -0
- data/doc/ex/font_styles.rb +34 -0
- data/doc/ex/fonts.rb +20 -0
- data/doc/ex/frame.rb +12 -0
- data/doc/ex/gaussian_blur.rb +11 -0
- data/doc/ex/get_multiline_type_metrics.rb +42 -0
- data/doc/ex/get_pixels.rb +48 -0
- data/doc/ex/get_type_metrics.rb +146 -0
- data/doc/ex/gradientfill.rb +27 -0
- data/doc/ex/grav.rb +46 -0
- data/doc/ex/gravity.rb +79 -0
- data/doc/ex/group.rb +26 -0
- data/doc/ex/hatchfill.rb +27 -0
- data/doc/ex/image.rb +46 -0
- data/doc/ex/images/Apple.miff +0 -0
- data/doc/ex/images/Ballerina.jpg +0 -0
- data/doc/ex/images/Ballerina3.jpg +0 -0
- data/doc/ex/images/Button_0.gif +0 -0
- data/doc/ex/images/Button_1.gif +0 -0
- data/doc/ex/images/Button_2.gif +0 -0
- data/doc/ex/images/Button_3.gif +0 -0
- data/doc/ex/images/Button_4.gif +0 -0
- data/doc/ex/images/Button_5.gif +0 -0
- data/doc/ex/images/Button_6.gif +0 -0
- data/doc/ex/images/Button_7.gif +0 -0
- data/doc/ex/images/Button_8.gif +0 -0
- data/doc/ex/images/Button_9.gif +0 -0
- data/doc/ex/images/Button_A.gif +0 -0
- data/doc/ex/images/Button_B.gif +0 -0
- data/doc/ex/images/Button_C.gif +0 -0
- data/doc/ex/images/Button_D.gif +0 -0
- data/doc/ex/images/Button_E.gif +0 -0
- data/doc/ex/images/Button_F.gif +0 -0
- data/doc/ex/images/Button_G.gif +0 -0
- data/doc/ex/images/Button_H.gif +0 -0
- data/doc/ex/images/Button_I.gif +0 -0
- data/doc/ex/images/Button_J.gif +0 -0
- data/doc/ex/images/Button_K.gif +0 -0
- data/doc/ex/images/Button_L.gif +0 -0
- data/doc/ex/images/Button_M.gif +0 -0
- data/doc/ex/images/Button_N.gif +0 -0
- data/doc/ex/images/Button_O.gif +0 -0
- data/doc/ex/images/Button_P.gif +0 -0
- data/doc/ex/images/Button_Q.gif +0 -0
- data/doc/ex/images/Button_R.gif +0 -0
- data/doc/ex/images/Button_S.gif +0 -0
- data/doc/ex/images/Button_T.gif +0 -0
- data/doc/ex/images/Button_U.gif +0 -0
- data/doc/ex/images/Button_V.gif +0 -0
- data/doc/ex/images/Button_W.gif +0 -0
- data/doc/ex/images/Button_X.gif +0 -0
- data/doc/ex/images/Button_Y.gif +0 -0
- data/doc/ex/images/Button_Z.gif +0 -0
- data/doc/ex/images/Cheetah.jpg +0 -0
- data/doc/ex/images/Coffee.wmf +0 -0
- data/doc/ex/images/Flower_Hat.jpg +0 -0
- data/doc/ex/images/Gold_Statue.jpg +0 -0
- data/doc/ex/images/Hot_Air_Balloons.jpg +0 -0
- data/doc/ex/images/Hot_Air_Balloons_H.jpg +0 -0
- data/doc/ex/images/Leaf.miff +0 -0
- data/doc/ex/images/No.wmf +0 -0
- data/doc/ex/images/Polynesia.jpg +0 -0
- data/doc/ex/images/Red_Rocks.jpg +0 -0
- data/doc/ex/images/Rocks_On_Beach.miff +0 -0
- data/doc/ex/images/Shorts.jpg +0 -0
- data/doc/ex/images/Snake.wmf +0 -0
- data/doc/ex/images/Violin.jpg +0 -0
- data/doc/ex/images/Yellow_Rose.miff +0 -0
- data/doc/ex/images/big-duck.gif +0 -0
- data/doc/ex/images/duck.gif +0 -0
- data/doc/ex/images/duck0.gif +0 -0
- data/doc/ex/images/duck1.gif +0 -0
- data/doc/ex/images/duck10.gif +0 -0
- data/doc/ex/images/duck11.gif +0 -0
- data/doc/ex/images/duck12.gif +0 -0
- data/doc/ex/images/duck13.gif +0 -0
- data/doc/ex/images/duck14.gif +0 -0
- data/doc/ex/images/duck15.gif +0 -0
- data/doc/ex/images/duck2.gif +0 -0
- data/doc/ex/images/duck3.gif +0 -0
- data/doc/ex/images/duck4.gif +0 -0
- data/doc/ex/images/duck5.gif +0 -0
- data/doc/ex/images/duck6.gif +0 -0
- data/doc/ex/images/duck7.gif +0 -0
- data/doc/ex/images/duck8.gif +0 -0
- data/doc/ex/images/duck9.gif +0 -0
- data/doc/ex/images/graydient230x6.gif +0 -0
- data/doc/ex/images/logo400x83.gif +0 -0
- data/doc/ex/images/model.miff +0 -0
- data/doc/ex/images/notimplemented.gif +0 -0
- data/doc/ex/images/smile.miff +0 -0
- data/doc/ex/images/spin.gif +0 -0
- data/doc/ex/implode.rb +34 -0
- data/doc/ex/level.rb +11 -0
- data/doc/ex/level_colors.rb +11 -0
- data/doc/ex/line.rb +42 -0
- data/doc/ex/line01.rb +23 -0
- data/doc/ex/mask.rb +36 -0
- data/doc/ex/matte_fill_to_border.rb +40 -0
- data/doc/ex/matte_floodfill.rb +33 -0
- data/doc/ex/matte_replace.rb +40 -0
- data/doc/ex/median_filter.rb +28 -0
- data/doc/ex/modulate.rb +11 -0
- data/doc/ex/mono.rb +23 -0
- data/doc/ex/morph.rb +26 -0
- data/doc/ex/mosaic.rb +35 -0
- data/doc/ex/motion_blur.rb +11 -0
- data/doc/ex/negate.rb +11 -0
- data/doc/ex/negate_channel.rb +9 -0
- data/doc/ex/nested_rvg.rb +21 -0
- data/doc/ex/nonzero.rb +43 -0
- data/doc/ex/normalize.rb +11 -0
- data/doc/ex/oil_paint.rb +11 -0
- data/doc/ex/opacity.rb +37 -0
- data/doc/ex/ordered_dither.rb +11 -0
- data/doc/ex/path.rb +64 -0
- data/doc/ex/pattern1.rb +25 -0
- data/doc/ex/pattern2.rb +26 -0
- data/doc/ex/polaroid.rb +28 -0
- data/doc/ex/polygon.rb +24 -0
- data/doc/ex/polygon01.rb +23 -0
- data/doc/ex/polyline.rb +23 -0
- data/doc/ex/polyline01.rb +23 -0
- data/doc/ex/posterize.rb +8 -0
- data/doc/ex/preview.rb +9 -0
- data/doc/ex/qbezierpath.rb +52 -0
- data/doc/ex/quad01.rb +36 -0
- data/doc/ex/quantize-m.rb +25 -0
- data/doc/ex/radial_blur.rb +9 -0
- data/doc/ex/raise.rb +8 -0
- data/doc/ex/random_threshold_channel.rb +13 -0
- data/doc/ex/rect01.rb +15 -0
- data/doc/ex/rect02.rb +22 -0
- data/doc/ex/rectangle.rb +35 -0
- data/doc/ex/reduce_noise.rb +28 -0
- data/doc/ex/remap.rb +12 -0
- data/doc/ex/remap_images.rb +21 -0
- data/doc/ex/resize_to_fill.rb +10 -0
- data/doc/ex/resize_to_fit.rb +10 -0
- data/doc/ex/roll.rb +9 -0
- data/doc/ex/rotate.rb +45 -0
- data/doc/ex/rotate_f.rb +14 -0
- data/doc/ex/roundrect.rb +34 -0
- data/doc/ex/rubyname.rb +30 -0
- data/doc/ex/rvg_clippath.rb +14 -0
- data/doc/ex/rvg_linecap.rb +43 -0
- data/doc/ex/rvg_linejoin.rb +41 -0
- data/doc/ex/rvg_opacity.rb +19 -0
- data/doc/ex/rvg_pattern.rb +26 -0
- data/doc/ex/rvg_stroke_dasharray.rb +12 -0
- data/doc/ex/segment.rb +11 -0
- data/doc/ex/sepiatone.rb +8 -0
- data/doc/ex/shade.rb +11 -0
- data/doc/ex/shadow.rb +31 -0
- data/doc/ex/shave.rb +15 -0
- data/doc/ex/shear.rb +10 -0
- data/doc/ex/sketch.rb +18 -0
- data/doc/ex/skewx.rb +52 -0
- data/doc/ex/skewy.rb +47 -0
- data/doc/ex/smile.rb +125 -0
- data/doc/ex/solarize.rb +11 -0
- data/doc/ex/sparse_color.rb +55 -0
- data/doc/ex/splice.rb +9 -0
- data/doc/ex/spread.rb +11 -0
- data/doc/ex/stegano.rb +55 -0
- data/doc/ex/stroke_dasharray.rb +43 -0
- data/doc/ex/stroke_fill.rb +11 -0
- data/doc/ex/stroke_linecap.rb +44 -0
- data/doc/ex/stroke_linejoin.rb +48 -0
- data/doc/ex/stroke_width.rb +49 -0
- data/doc/ex/swirl.rb +17 -0
- data/doc/ex/text.rb +37 -0
- data/doc/ex/text01.rb +17 -0
- data/doc/ex/text_align.rb +36 -0
- data/doc/ex/text_antialias.rb +38 -0
- data/doc/ex/text_styles.rb +21 -0
- data/doc/ex/text_undercolor.rb +28 -0
- data/doc/ex/texture_fill_to_border.rb +34 -0
- data/doc/ex/texture_floodfill.rb +32 -0
- data/doc/ex/texturefill.rb +25 -0
- data/doc/ex/threshold.rb +13 -0
- data/doc/ex/to_blob.rb +14 -0
- data/doc/ex/translate.rb +39 -0
- data/doc/ex/transparent.rb +38 -0
- data/doc/ex/transpose.rb +9 -0
- data/doc/ex/transverse.rb +9 -0
- data/doc/ex/tref01.rb +25 -0
- data/doc/ex/triangle01.rb +16 -0
- data/doc/ex/trim.rb +24 -0
- data/doc/ex/tspan01.rb +18 -0
- data/doc/ex/tspan02.rb +19 -0
- data/doc/ex/tspan03.rb +21 -0
- data/doc/ex/unsharp_mask.rb +28 -0
- data/doc/ex/viewex.rb +35 -0
- data/doc/ex/vignette.rb +12 -0
- data/doc/ex/watermark.rb +28 -0
- data/doc/ex/wave.rb +9 -0
- data/doc/ex/wet_floor.rb +59 -0
- data/doc/ex/writing_mode01.rb +27 -0
- data/doc/ex/writing_mode02.rb +26 -0
- data/doc/ilist.html +2056 -0
- data/doc/image1.html +4680 -0
- data/doc/image2.html +3665 -0
- data/doc/image3.html +4522 -0
- data/doc/imageattrs.html +1638 -0
- data/doc/imusage.html +514 -0
- data/doc/index.html +416 -0
- data/doc/info.html +1499 -0
- data/doc/magick.html +565 -0
- data/doc/optequiv.html +2435 -0
- data/doc/rvg.html +975 -0
- data/doc/rvgclip.html +248 -0
- data/doc/rvggroup.html +305 -0
- data/doc/rvgimage.html +289 -0
- data/doc/rvgpattern.html +475 -0
- data/doc/rvgshape.html +406 -0
- data/doc/rvgstyle.html +270 -0
- data/doc/rvgtext.html +465 -0
- data/doc/rvgtspan.html +238 -0
- data/doc/rvgtut.html +530 -0
- data/doc/rvguse.html +145 -0
- data/doc/rvgxform.html +294 -0
- data/doc/scripts/doc.js +22 -0
- data/doc/scripts/stripeTables.js +23 -0
- data/doc/struct.html +1339 -0
- data/doc/usage.html +1621 -0
- data/examples/constitute.rb +7 -0
- data/examples/crop_with_gravity.rb +46 -0
- data/examples/demo.rb +324 -0
- data/examples/describe.rb +44 -0
- data/examples/find_similar_region.rb +34 -0
- data/examples/histogram.rb +325 -0
- data/examples/identify.rb +187 -0
- data/examples/image_opacity.rb +29 -0
- data/examples/import_export.rb +31 -0
- data/examples/pattern_fill.rb +38 -0
- data/examples/rotating_text.rb +45 -0
- data/examples/spinner.rb +50 -0
- data/examples/thumbnail.rb +65 -0
- data/examples/vignette.rb +79 -0
- data/ext/RMagick/Makefile +180 -0
- data/ext/RMagick/RMagick2.so +0 -0
- data/ext/RMagick/extconf.h +119 -0
- data/ext/RMagick/extconf.rb +406 -0
- data/ext/RMagick/mkmf.log +3022 -0
- data/ext/RMagick/rmagick.c +394 -0
- data/ext/RMagick/rmagick.h +1307 -0
- data/ext/RMagick/rmagick.o +0 -0
- data/ext/RMagick/rmdraw.c +1991 -0
- data/ext/RMagick/rmdraw.o +0 -0
- data/ext/RMagick/rmenum.c +1224 -0
- data/ext/RMagick/rmenum.o +0 -0
- data/ext/RMagick/rmfill.c +717 -0
- data/ext/RMagick/rmfill.o +0 -0
- data/ext/RMagick/rmilist.c +1217 -0
- data/ext/RMagick/rmilist.o +0 -0
- data/ext/RMagick/rmimage.c +15099 -0
- data/ext/RMagick/rmimage.o +0 -0
- data/ext/RMagick/rminfo.c +2567 -0
- data/ext/RMagick/rminfo.o +0 -0
- data/ext/RMagick/rmmain.c +1705 -0
- data/ext/RMagick/rmmain.o +0 -0
- data/ext/RMagick/rmmontage.c +511 -0
- data/ext/RMagick/rmmontage.o +0 -0
- data/ext/RMagick/rmpixel.c +1103 -0
- data/ext/RMagick/rmpixel.o +0 -0
- data/ext/RMagick/rmstruct.c +1047 -0
- data/ext/RMagick/rmstruct.o +0 -0
- data/ext/RMagick/rmutil.c +1730 -0
- data/ext/RMagick/rmutil.o +0 -0
- data/lib/RMagick.rb +1962 -0
- data/lib/rvg/clippath.rb +48 -0
- data/lib/rvg/container.rb +131 -0
- data/lib/rvg/deep_equal.rb +56 -0
- data/lib/rvg/describable.rb +53 -0
- data/lib/rvg/embellishable.rb +417 -0
- data/lib/rvg/misc.rb +740 -0
- data/lib/rvg/paint.rb +55 -0
- data/lib/rvg/pathdata.rb +131 -0
- data/lib/rvg/rvg.rb +283 -0
- data/lib/rvg/stretchable.rb +168 -0
- data/lib/rvg/stylable.rb +124 -0
- data/lib/rvg/text.rb +187 -0
- data/lib/rvg/to_c.rb +103 -0
- data/lib/rvg/transformable.rb +133 -0
- data/lib/rvg/units.rb +66 -0
- data/metaconfig +7 -0
- data/post-clean.rb +12 -0
- data/post-install.rb +50 -0
- data/post-setup.rb +254 -0
- data/rmagick.gemspec +20 -0
- data/setup.rb +1585 -0
- data/test/Draw.rb +121 -0
- data/test/Image1.rb +762 -0
- data/test/Image2.rb +1308 -0
- data/test/Image3.rb +1001 -0
- data/test/ImageList1.rb +808 -0
- data/test/ImageList2.rb +389 -0
- data/test/Image_attributes.rb +682 -0
- data/test/Import_Export.rb +116 -0
- data/test/Info.rb +349 -0
- data/test/Magick.rb +364 -0
- data/test/Pixel.rb +120 -0
- data/test/Preview.rb +62 -0
- data/test/all_basic.rb +39 -0
- data/test/cmyk.icm +0 -0
- data/test/srgb.icm +0 -0
- data/test/test.0 +0 -0
- data/uninstall.rb +74 -0
- metadata +455 -0
data/README-Mac-OSX.txt
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
For installation instructions see http://rmagick.rubyforge.org/install-osx.html
|
data/README.md
ADDED
@@ -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 © 2002-2009 by Timothy P. Hunter
|
207
|
+
|
208
|
+
Changes since Nov. 2009 copyright © 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/.
|
data/build_tarball.rake
ADDED
@@ -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
|
+
|
data/doc/comtasks.html
ADDED
@@ -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
|
+
« <a href="optequiv.html">Prev</a> | <a href=
|
38
|
+
"index.html">Contents</a> | <a href=
|
39
|
+
"magick.html">Next</a> »
|
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 > 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
|
+
« <a href="optequiv.html">Prev</a> | <a href=
|
283
|
+
"index.html">Contents</a> | <a href="magick.html">Next</a>
|
284
|
+
»
|
285
|
+
</div>
|
286
|
+
</body>
|
287
|
+
</html>
|