blob: 132b6220079446afac6fe58285fbc69194746fe7 [file] [log] [blame]
Cristy594d2772015-11-15 10:47:42 -05001
2
3
4
Cristy882d9f42015-10-29 16:48:39 -04005<!DOCTYPE html>
6<html lang="en">
7<head>
Cristy912a9222016-06-17 15:37:28 -04008 <meta charset="utf-8" />
Cristy3b0b58d2016-11-06 07:40:23 -05009 <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" />
10 <meta http-equiv="x-ua-compatible" content="ie=edge" />
Cristy6549abb2016-11-10 08:25:55 -050011 <title>Image Gradients @ ImageMagick</title>
Cristy594d2772015-11-15 10:47:42 -050012 <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
13 <meta name="application-name" content="ImageMagick"/>
14 <meta name="description" content="ImageMagick® is a software suite to create, edit, compose, or convert bitmap images. It can read and write images in a variety of formats (over 200) including PNG, JPEG, JPEG-2000, GIF, WebP, Postscript, PDF, and SVG. Use ImageMagick to resize, flip, mirror, rotate, distort, shear and transform images, adjust image colors, apply various special effects, or draw text, lines, polygons, ellipses and Bézier curves."/>
Cristy364a72f2016-11-04 22:38:41 -040015 <meta name="application-url" content="https://www.imagemagick.org"/>
Cristy594d2772015-11-15 10:47:42 -050016 <meta name="generator" content="PHP"/>
17 <meta name="keywords" content="image, gradients, ImageMagick, PerlMagick, image processing, image, photo, software, Magick++, OpenMP, convert"/>
18 <meta name="rating" content="GENERAL"/>
19 <meta name="robots" content="INDEX, FOLLOW"/>
20 <meta name="generator" content="ImageMagick Studio LLC"/>
21 <meta name="author" content="ImageMagick Studio LLC"/>
22 <meta name="revisit-after" content="2 DAYS"/>
23 <meta name="resource-type" content="document"/>
Cristy912a9222016-06-17 15:37:28 -040024 <meta name="copyright" content="Copyright (c) 1999-2016 ImageMagick Studio LLC"/>
Cristy594d2772015-11-15 10:47:42 -050025 <meta name="distribution" content="Global"/>
26 <meta name="magick-serial" content="P131-S030410-R485315270133-P82224-A6668-G1245-1"/>
Cristy912a9222016-06-17 15:37:28 -040027 <meta name="google-site-verification" content="_bMOCDpkx9ZAzBwb2kF3PRHbfUUdFj2uO8Jd1AXArz4" />
Cristy6549abb2016-11-10 08:25:55 -050028 <link rel="canonical" href="https://www.imagemagick.org/script/gradient.html"/>
Cristy594d2772015-11-15 10:47:42 -050029 <link rel="icon" href="../images/wand.png"/>
30 <link rel="shortcut icon" href="../images/wand.ico"/>
Cristy6549abb2016-11-10 08:25:55 -050031 <link rel="stylesheet" type="text/css" href="http://fonts.googleapis.com/css?family=Roboto:900,400,400italic,700,700italic,300,300italic|Open+Sans:300italic,400italic,700italic,300,400,600,700">
Cristyce4a3552015-12-14 13:53:35 -050032 <link rel="stylesheet" href="css/magick.css"/>
Cristy882d9f42015-10-29 16:48:39 -040033</head>
34<body>
35<div class="main">
36<div class="magick-masthead">
37 <div class="container">
Cristy6549abb2016-11-10 08:25:55 -050038 <script async="async" src="http://localhost/pagead/js/adsbygoogle.js"></script> <ins class="adsbygoogle"
Cristy594d2772015-11-15 10:47:42 -050039 style="display:block"
40 data-ad-client="ca-pub-3129977114552745"
41 data-ad-slot="6345125851"
42 data-ad-format="auto"></ins>
Cristy882d9f42015-10-29 16:48:39 -040043 <script>
44 (adsbygoogle = window.adsbygoogle || []).push({});
45 </script>
46 <nav class="magick-nav">
47 <a class="magick-nav-item " href="../index.html">Home</a>
48 <a class="magick-nav-item " href="binary-releases.html">Download</a>
49 <a class="magick-nav-item " href="command-line-tools.html">Tools</a>
Cristye93be682015-11-26 09:07:51 -050050 <a class="magick-nav-item " href="command-line-processing.html">Command-line</a>
Cristy882d9f42015-10-29 16:48:39 -040051 <a class="magick-nav-item " href="resources.html">Resources</a>
52 <a class="magick-nav-item " href="api.html">Develop</a>
Cristy6549abb2016-11-10 08:25:55 -050053 <a class="magick-nav-item " href="https://www.imagemagick.org/script/search.php">Search</a>
54 <a class="magick-nav-item pull-right" href="https://www.imagemagick.org/discourse-server/">Community</a>
Cristy882d9f42015-10-29 16:48:39 -040055 </nav>
56 </div>
57</div>
58<div class="container">
59<div class="magick-header">
60
Cristye93be682015-11-26 09:07:51 -050061<p class="lead magick-description">An image gradient creates a gradual blend between two colors formed into a shape that is linear, circular, or ellipical.</p>
Cristy882d9f42015-10-29 16:48:39 -040062
Cristye93be682015-11-26 09:07:51 -050063<p>For a linear gradient, the operator is either:</p>
Cristy882d9f42015-10-29 16:48:39 -040064
65<pre>
66gradient:
Cristye93be682015-11-26 09:07:51 -050067gradient:color1-color2
Cristy882d9f42015-10-29 16:48:39 -040068</pre>
69
Cristye93be682015-11-26 09:07:51 -050070<p> The for a radial gradient, the operator is either:</p>
Cristy882d9f42015-10-29 16:48:39 -040071
72<pre>
73radial-gradient:
Cristye93be682015-11-26 09:07:51 -050074radial-gradient:color1-color2
Cristy882d9f42015-10-29 16:48:39 -040075</pre>
76
Cristye93be682015-11-26 09:07:51 -050077<p> In the above, color1 is the fromColor and color2 is the toColor, as described in more detail below. The default is white for color1 and black for color2, i.e., white-black.</p>
Cristy882d9f42015-10-29 16:48:39 -040078
Cristye93be682015-11-26 09:07:51 -050079<p>The default for a linear gradient has color1 at the top of the image and color2 at the bottom of the image. Similarly, the default for a radial gradient has color1 at the center of the image and color2 at the boundary of the image.</p>
Cristy882d9f42015-10-29 16:48:39 -040080
Cristy6549abb2016-11-10 08:25:55 -050081<p>Gradient colors may be any valid color defined per <a href="https://www.imagemagick.org/script/color.html" target="_blank">https://www.imagemagick.org/script/color.html</a>. The named colors of black/white/grayXX are non-linear gray gradients; whereas gray(XX[%]) is a linear gray gradient. For Unix systems, enclose rgb(a) and hex colors in quotes. Use double quotes, if using variables for the values.</p>
Cristy882d9f42015-10-29 16:48:39 -040082
Cristye93be682015-11-26 09:07:51 -050083<p>Here is an example linear gradient:</p>
Cristy882d9f42015-10-29 16:48:39 -040084
85<pre>
Cristye93be682015-11-26 09:07:51 -050086convert -size 256x256 gradient: linear_gradient.png
87convert -size 256x256 gradient:white-black linear_gradient.png
Cristy882d9f42015-10-29 16:48:39 -040088</pre>
Cristy1f1f3a02016-06-01 07:25:42 -040089<p><img src="../images/gradients/linear_gradient.png" width="256" height="256"></p>
Cristy882d9f42015-10-29 16:48:39 -040090
Cristye93be682015-11-26 09:07:51 -050091<p>If you want a radial gradient, try:</p>
Cristy882d9f42015-10-29 16:48:39 -040092
93<pre>
Cristye93be682015-11-26 09:07:51 -050094convert -size 256x256 radial-gradient: radial_gradient.png
95convert -size 256x256 radial-gradient:white-black radial_gradient.png
Cristy882d9f42015-10-29 16:48:39 -040096</pre>
Cristy1f1f3a02016-06-01 07:25:42 -040097<p><img src="../images/gradients/radial_gradient.png" width="256" height="256"></p>
Cristy882d9f42015-10-29 16:48:39 -040098
Cristye93be682015-11-26 09:07:51 -050099<p>As of IM 6.9.2.5, gradients have been enhanced through the use of several -defines.</p>
Cristy882d9f42015-10-29 16:48:39 -0400100
101<table class="table table-condensed table-striped">
102 <tr>
Cristye93be682015-11-26 09:07:51 -0500103 <td><code>-define gradient:vector=<var>x1</var>,<var>y1</var>, <var>x2</var>,<var>y2</var></code> <code></td>
Cristy882d9f42015-10-29 16:48:39 -0400104 <td>Specifies the direction of the linear gradient going from vector1
Cristye93be682015-11-26 09:07:51 -0500105 (x1,y1) to vector2 (x2,y2). Color1 (fromColor) will be located at vector
106 position x1,y1 and color2 (toColor) will be located at vector position
Cristy882d9f42015-10-29 16:48:39 -0400107 x2,y2.</td>
108 </tr>
109
110 <tr>
111 <td><code>-define gradient:center=<var>x</var>,<var>y</var></code></td>
112 <td>Specifies the coordinates of the center point for the radial gradient.
113 The default is the center of the image.</td>
114 </tr>
115
116 <tr>
117 <td><code>-define gradient:radii=<var>x</var>,<var>y</var></code></td>
118 <td>Specifies the x and y radii of the gradient. If the x radius and the y
Cristye93be682015-11-26 09:07:51 -0500119 radius are equal, the shape of the radial gradient will be a circle. If
120 they differ, then the shape will be an ellipse. The default values are the
Cristy882d9f42015-10-29 16:48:39 -0400121 maximum of the half width and half height of the image.</td>
122 </tr>
123
124 <tr>
Cristye93be682015-11-26 09:07:51 -0500125 <td><code>-define gradient:angle=<var>angle in degrees</var></code></td>
126 <td>For a linear gradient, this specifies the direction of the gradient
127 going from color1 to color2 in a clockwise positive manner relative to
128 north (up). For a radial gradient, this specifies the rotation of the
129 gradient in a clockwise positive manner from its normal X-Y
Cristy882d9f42015-10-29 16:48:39 -0400130 orientation.</td>
131 </tr>
Cristye93be682015-11-26 09:07:51 -0500132
133 <tr>
134 <td><code>-define gradient:bounding-box=<var>width</var>x<var>height</var>+<var>x</var>+<var>y</var></code></td>
135 <td>Limits the gradient to a larger or smaller region than the image
136 dimensions. If the region defined by the bounding box is smaller than the
137 image, then color1 will be the color of the background.</td>
138 </tr>
Cristy882d9f42015-10-29 16:48:39 -0400139</table>
140
141
Cristye93be682015-11-26 09:07:51 -0500142<p>We also support two convenience defines for setting the linear gradient direction and the radial gradient shape.</p>
Cristy882d9f42015-10-29 16:48:39 -0400143
144<table class="table table-condensed table-striped">
145 <tr>
146 <td><code>-define gradient:direction=<em>{NorthWest, North, Northeast, West, East, SouthWest, South, SouthEast}</em></code></td>
Cristye93be682015-11-26 09:07:51 -0500147 <td>Specifies the direction of the linear gradient towards the
Cristy882d9f42015-10-29 16:48:39 -0400148 top/bottom/left/right or diagonal corners.</td>
149 </tr>
150
151 <tr>
Cristy594d2772015-11-15 10:47:42 -0500152 <td><code>-define gradient:extent=<em>{Circle, Diagonal, Ellipse, Maximum, Minimum}</code></td>
Cristye93be682015-11-26 09:07:51 -0500153 <td>Specifies the shape of an image centered radial gradient. Circle and
Cristy882d9f42015-10-29 16:48:39 -0400154 Maximum draw a circular radial gradient even for rectangular shaped images
155 of radius equal to the larger of the half-width and half-height of the
156 image. The Circle and Maximum options are both equivalent to the default
157 radial gradient. The Minimum option draws a circular radial gradient
158 even for rectangular shaped images of radius equal to the smaller of the
159 half-width and half-height of the image. The Diagonal option draws a
160 circular radial gradient even for rectangular shaped images of radius equal
161 to the half-diagonal of the image. The Ellipse options draws an elliptical
162 radial gradient for rectangular shaped images of radii equal to half the
163 width and half the height of the image.</td>
164 </tr>
165</table>
166
Cristye93be682015-11-26 09:07:51 -0500167<p>Examples</p>
Cristy882d9f42015-10-29 16:48:39 -0400168
Cristye93be682015-11-26 09:07:51 -0500169<p>The default linear gradient may also be generated in any of the following ways (or by reversing the direction and swapping color1 and color2):</p>
Cristy882d9f42015-10-29 16:48:39 -0400170
171<pre>
Cristye93be682015-11-26 09:07:51 -0500172convert -size 256x128 -define gradient:direction=north gradient:black-white linear_gradient_default.png
173convert -size 256x128 -define gradient:angle=0 gradient:black-white linear_gradient_default.png
Cristy882d9f42015-10-29 16:48:39 -0400174</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400175<p><img src="../images/gradients/linear_gradient_default.png" width="256" height="128"></p>
Cristy882d9f42015-10-29 16:48:39 -0400176
Cristye93be682015-11-26 09:07:51 -0500177<p>The equivalent of </p>
Cristy882d9f42015-10-29 16:48:39 -0400178
179<pre>
Cristye93be682015-11-26 09:07:51 -0500180convert -size 128x256 gradient: -rotate 90 linear_gradient_east.png
Cristy882d9f42015-10-29 16:48:39 -0400181</pre>
182
Cristye93be682015-11-26 09:07:51 -0500183<p>can be generate by either of the following (or by reversing the direction and swapping color1 and color2):</p>
Cristy882d9f42015-10-29 16:48:39 -0400184
185<pre>
Cristye93be682015-11-26 09:07:51 -0500186convert -size 256x128 -define gradient:direction=east gradient:black-white linear_gradient_east.png
187convert -size 256x128 -define gradient:angle=90 gradient:black-white linear_gradient_east.png
Cristy882d9f42015-10-29 16:48:39 -0400188</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400189<p><img src="../images/gradients/linear_gradient_east.png" width="256" height="128"></p>
Cristy882d9f42015-10-29 16:48:39 -0400190
191
Cristye93be682015-11-26 09:07:51 -0500192<p>Examples of radial gradients going from black in the center to white at the boundary for the cases of "maximum/circle/default", "minimum", "diagonal", "ellipse" and 45 degree rotated ellipse, respectively, follow below.</p>
Cristy882d9f42015-10-29 16:48:39 -0400193
194
195<pre>
Cristye93be682015-11-26 09:07:51 -0500196convert -size 256x128 radial-gradient:black-white radial_gradient_maximum.png
197convert -size 256x128 -define gradient:radii=128,128 radial-gradient:black-white radial_gradient_maximum.png
Cristy882d9f42015-10-29 16:48:39 -0400198</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400199<p><img src="../images/gradients/radial_gradient_maximum.png" width="256" height="128"></p>
Cristye93be682015-11-26 09:07:51 -0500200
201<pre>
202convert -size 256x128 -define gradient:extent=minimum radial-gradient:black-white radial_gradient_minimum.png
203convert -size 256x128 -define gradient:radii=64,64 radial-gradient:black-white radial_gradient_minimum.png
204</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400205<p><img src="../images/gradients/radial_gradient_minimum.png" width="256" height="128"></p>
Cristye93be682015-11-26 09:07:51 -0500206
207<pre>
208convert -size 256x128 -define gradient:extent=diagonal radial-gradient:black-white radial_gradient_diagonal.png
209</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400210<p><img src="../images/gradients/radial_gradient_diagonal.png" width="256" height="128"></p>
Cristye93be682015-11-26 09:07:51 -0500211
212<pre>
213convert -size 256x128 -define gradient:extent=ellipse radial-gradient:black-white radial_gradient_ellipse.png
214convert -size 256x128 -define gradient:radii=128,64 radial-gradient:black-white radial_gradient_ellipse.png
215</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400216<p><img src="../images/gradients/radial_gradient_ellipse.png" width="256" height="128"></p>
Cristye93be682015-11-26 09:07:51 -0500217
218<pre>
219convert -size 256x256 -define gradient:radii=128,64 -define gradient:angle=45 radial-gradient:black-white radial_gradient_ellipse_angle45.png
220</pre>
Cristy1f1f3a02016-06-01 07:25:42 -0400221<p><img src="../images/gradients/radial_gradient_ellipse_angle45.png" width="256" height="256"></p>
Cristye93be682015-11-26 09:07:51 -0500222
Cristy882d9f42015-10-29 16:48:39 -0400223</div>
224
225 <footer class="magick-footer">
226 <p><a href="support.html">Donate</a>
227 <a href="sitemap.html">Sitemap</a>
228 <a href="links.html">Related</a>
Cristye0779712016-07-30 17:25:22 -0400229 <a href="security-policy.html">Security</a>
Cristy882d9f42015-10-29 16:48:39 -0400230 <a href="architecture.html">Architecture</a>
231</p>
232 <p><a href="gradient.html#">Back to top</a>
233 <a href="http://pgp.mit.edu:11371/pks/lookup?op=get&amp;search=0x89AB63D48277377A">Public Key</a>
Cristy6549abb2016-11-10 08:25:55 -0500234 <a href="https://www.imagemagick.org/script/contact.php">Contact Us</a></p>
Cristyde27d762016-01-02 12:56:44 -0500235 <p><small>© 1999-2016 ImageMagick Studio LLC</small></p>
Cristy882d9f42015-10-29 16:48:39 -0400236 </footer>
237</div><!-- /.container -->
238
239 <script src="https://localhost/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
Cristy1f1f3a02016-06-01 07:25:42 -0400240 <script src="../js/magick.html"></script>
Cristy882d9f42015-10-29 16:48:39 -0400241</div>
242</body>
243</html>
Cristy6549abb2016-11-10 08:25:55 -0500244<!-- Magick Cache 10th November 2016 08:07 -->