• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1
2
3
4
5<!doctype html>
6<html lang="en">
7<head>
8  <meta charset="utf-8"  />
9  <meta name="viewport" content="width=device-width, initial-scale=1"  />
10  <title>ImageMagick - MagickCore, C API: Image Histograms</title>
11  <meta name="application-name" content="ImageMagick" />
12  <meta name="description" content="Use ImageMagick® to create, edit, compose, and convert digital images. Resize an image, crop it, change its shades and colors, add captions, and more." />
13  <meta name="application-url" content="https://imagemagick.org" />
14  <meta name="generator" content="PHP" />
15  <meta name="keywords" content="magickcore, c, api:, image, histograms, image processing software" />
16  <meta name="rating" content="GENERAL" />
17  <meta name="robots" content="INDEX, FOLLOW" />
18  <meta name="generator" content="ImageMagick Studio LLC" />
19  <meta name="author" content="ImageMagick Studio LLC" />
20  <meta name="revisit-after" content="2 DAYS" />
21  <meta name="resource-type" content="document" />
22  <meta name="copyright" content="Copyright (c) 1999-2020 ImageMagick Studio LLC" />
23  <meta name="distribution" content="Global" />
24  <meta name="magick-serial" content="P131-S030410-R485315270133-P82224-A6668-G1245-1" />
25  <meta property='og:url' content='../../' />
26  <meta property='og:title' content='ImageMagick' />
27  <meta property='og:image' content='../../../images/logo.png' />
28  <meta property='og:type' content='website' />
29  <meta property='og:site_name' content='ImageMagick' />
30  <meta property='og:description' content="Create, Edit, Compose, or Convert Digital Images" />
31  <meta name="google-site-verification" content="_bMOCDpkx9ZAzBwb2kF3PRHbfUUdFj2uO8Jd1AXArz4" />
32  <link href="histogram.html" rel="canonical" />
33  <link href="../../../images/wand.png" rel="icon" />
34  <link href="../../../images/wand.ico" rel="shortcut icon" />
35  <link href="../../assets/magick.css" rel="stylesheet" />
36</head>
37<body>
38  <nav class="navbar navbar-expand-md navbar-dark bg-dark fixed-top">
39  <div class="container-fluid">
40    <a class="navbar-brand" href="../../"><img class="d-block" id="icon" alt="ImageMagick" width="32" height="32" src="../../../images/wand.ico"/></a>
41    <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#magick-navbars" aria-controls="magick-navbars" aria-expanded="false" aria-label="Toggle navigation">
42      <span class="navbar-toggler-icon"></span>
43    </button>
44
45    <div class="collapse navbar-collapse" id="magick-navbars">
46      <ul class="navbar-nav me-auto mb-2 mb-md-0">
47        <li class="nav-item">
48          <a class="nav-link " href="../../www/index.html">Home</a>
49        </li>
50        <li class="nav-item">
51          <a class="nav-link " href="../../www/download.html">Download</a>
52        </li>
53        <li class="nav-item">
54          <a class="nav-link " href="../../www/command-line-tools.html">Tools</a>
55        </li>
56        <li class="nav-item">
57          <a class="nav-link " href="../../www/command-line-processing.html">CLI</a>
58        </li>
59        <li class="nav-item">
60          <a class="nav-link " href="../../www/develop.html">Develop</a>
61        </li>
62        <li class="nav-item">
63          <a class="nav-link" target="_blank" href="https://github.com/ImageMagick/ImageMagick/discussions">Community</a>
64        </li>
65        <li class="nav-item">
66          <iframe src="https://github.com/sponsors/ImageMagick/button" title="Sponsor ImageMagick" height="35" width="107" style="border: 0;"></iframe>
67        </li>
68      </ul>
69      <form class="d-flex form-inline" action="https://imagemagick.org/script/search.php">
70        <input class="form-control me-2" type="text" name="q" placeholder="Search" aria-label="Search">
71        <button class="btn btn-outline-success" type="submit" name="sa">Search</button>
72      </form>
73    </div>
74  </div>
75  </nav>
76
77  <div class="container">
78    <script async="async" src="https://localhost/pagead/js/adsbygoogle.js"></script>
79    <ins class="adsbygoogle"
80      style="display:block"
81      data-ad-client="ca-pub-3129977114552745"
82      data-ad-slot="6345125851"
83      data-full-width-responsive="true"
84      data-ad-format="horizontal"></ins>
85    <script>
86      (adsbygoogle = window.adsbygoogle || []).push({});
87    </script>
88
89  </div>
90
91  <main class="container">
92  <div class="magick-template">
93<div class="magick-header">
94<p class="text-center"><a href="histogram.html#GetImageHistogram">GetImageHistogram</a> &#8226; <a href="histogram.html#IdentifyPaletteImage">IdentifyPaletteImage</a> &#8226; <a href="histogram.html#IsHistogramImage">IsHistogramImage</a> &#8226; <a href="histogram.html#IsPaletteImage">IsPaletteImage</a> &#8226; <a href="histogram.html#MinMaxStretchImage">MinMaxStretchImage</a> &#8226; <a href="histogram.html#GetNumberColors">GetNumberColors</a> &#8226; <a href="histogram.html#UniqueImageColors">UniqueImageColors</a></p>
95
96<h2><a href="../../api/MagickCore/histogram_8c.html" id="GetImageHistogram">GetImageHistogram</a></h2>
97
98<p>GetImageHistogram() returns the unique colors in an image.</p>
99
100<p>The format of the GetImageHistogram method is:</p>
101
102<pre class="text">
103size_t GetImageHistogram(const Image *image,
104  size_t *number_colors,ExceptionInfo *exception)
105</pre>
106
107<p>A description of each parameter follows.</p>
108
109<dt>image</dt>
110<p>the image.</p>
111
112<dt>file</dt>
113<p>Write a histogram of the color distribution to this file handle.</p>
114
115<dt>exception</dt>
116<p>return any errors or warnings in this structure.</p>
117
118<h2><a href="../../api/MagickCore/histogram_8c.html" id="IdentifyPaletteImage">IdentifyPaletteImage</a></h2>
119
120<p>IdentifyPaletteImage() returns MagickTrue if the image has 256 unique colors or less.</p>
121
122<p>The format of the IdentifyPaletteImage method is:</p>
123
124<pre class="text">
125MagickBooleanType IdentifyPaletteImage(const Image *image,
126  ExceptionInfo *exception)
127</pre>
128
129<p>A description of each parameter follows.</p>
130
131<dt>image</dt>
132<p>the image.</p>
133
134<dt>exception</dt>
135<p>return any errors or warnings in this structure.</p>
136
137<h2><a href="../../api/MagickCore/histogram_8c.html" id="IsHistogramImage">IsHistogramImage</a></h2>
138
139<p>IsHistogramImage() returns MagickTrue if the image has 1024 unique colors or less.</p>
140
141<p>The format of the IsHistogramImage method is:</p>
142
143<pre class="text">
144MagickBooleanType IsHistogramImage(const Image *image,
145  ExceptionInfo *exception)
146</pre>
147
148<p>A description of each parameter follows.</p>
149
150<dt>image</dt>
151<p>the image.</p>
152
153<dt>exception</dt>
154<p>return any errors or warnings in this structure.</p>
155
156<h2><a href="../../api/MagickCore/histogram_8c.html" id="IsPaletteImage">IsPaletteImage</a></h2>
157
158<p>IsPaletteImage() returns MagickTrue if the image is PseudoClass and has 256 unique colors or less.</p>
159
160<p>The format of the IsPaletteImage method is:</p>
161
162<pre class="text">
163MagickBooleanType IsPaletteImage(const Image *image)
164</pre>
165
166<p>A description of each parameter follows.</p>
167
168<dt>image</dt>
169<p>the image.</p>
170
171<h2><a href="../../api/MagickCore/histogram_8c.html" id="MinMaxStretchImage">MinMaxStretchImage</a></h2>
172
173<p>MinMaxStretchImage() uses the exact minimum and maximum values found in each of the channels given, as the BlackPoint and WhitePoint to linearly stretch the colors (and histogram) of the image.  The stretch points are also moved further inward by the adjustment values given.</p>
174
175<p>If the adjustment values are both zero this function is equivalent to a perfect normalization (or autolevel) of the image.</p>
176
177<p>Each channel is stretched independantally of each other (producing color distortion) unless the special 'SyncChannels' flag is also provided in the channels setting. If this flag is present the minimum and maximum point will be extracted from all the given channels, and those channels will be stretched by exactly the same amount (preventing color distortion).</p>
178
179<p>In the special case that only ONE value is found in a channel of the image that value is not stretched, that value is left as is.</p>
180
181<p>The 'SyncChannels' is turned on in the 'DefaultChannels' setting by default.</p>
182
183<p>The format of the MinMaxStretchImage method is:</p>
184
185<pre class="text">
186MagickBooleanType MinMaxStretchImage(Image *image,const double black,
187  const double white,const double gamma,ExceptionInfo *exception)
188</pre>
189
190<p>A description of each parameter follows:</p>
191
192<dd>
193</dd>
194
195<dd> </dd>
196<dl class="dl-horizontal">
197<dt>image</dt>
198<dd>The image to auto-level </dd>
199
200<dd> </dd>
201<dt>black, white</dt>
202<dd> move the black / white point inward from the minimum and maximum points by this color value. </dd>
203
204<dd> </dd>
205<dt>gamma</dt>
206<dd>the gamma. </dd>
207
208<dd> </dd>
209<dt>exception</dt>
210<dd>return any errors or warnings in this structure. </dd>
211
212<dd>  </dd>
213</dl>
214<h2><a href="../../api/MagickCore/histogram_8c.html" id="GetNumberColors">GetNumberColors</a></h2>
215
216<p>GetNumberColors() returns the number of unique colors in an image.</p>
217
218<p>The format of the GetNumberColors method is:</p>
219
220<pre class="text">
221size_t GetNumberColors(const Image *image,FILE *file,
222  ExceptionInfo *exception)
223</pre>
224
225<p>A description of each parameter follows.</p>
226
227<dt>image</dt>
228<p>the image.</p>
229
230<dt>file</dt>
231<p>Write a histogram of the color distribution to this file handle.</p>
232
233<dt>exception</dt>
234<p>return any errors or warnings in this structure.</p>
235
236<h2><a href="../../api/MagickCore/histogram_8c.html" id="UniqueImageColors">UniqueImageColors</a></h2>
237
238<p>UniqueImageColors() returns the unique colors of an image.</p>
239
240<p>The format of the UniqueImageColors method is:</p>
241
242<pre class="text">
243Image *UniqueImageColors(const Image *image,ExceptionInfo *exception)
244</pre>
245
246<p>A description of each parameter follows.</p>
247
248<dt>image</dt>
249<p>the image.</p>
250
251<dt>exception</dt>
252<p>return any errors or warnings in this structure.</p>
253
254</div>
255  </div>
256  </main><!-- /.container -->
257  <footer class="magick-footer">
258    <div class="container-fluid">
259      <a href="../../www/security-policy.html">Security</a> •
260      <a href="../../www/news.html">News</a>
261
262      <a href="histogram.html#"><img class="d-inline" id="wand" alt="And Now a Touch of Magick" width="16" height="16" src="../../../images/wand.ico"/></a>
263
264      <a href="../../www/links.html">Related</a> •
265      <a href="../../www/sitemap.html">Sitemap</a>
266   <br/>
267     <a href="../../www/support.html">Sponsor</a> •
268     <a href="../../www/cite.html">Cite</a> •
269     <a href="http://pgp.mit.edu/pks/lookup?op=get&amp;search=0x89AB63D48277377A">Public Key</a> •
270     <a href="../../www/contact.html">Contact Us</a>
271   <br/>
272     <a href="https://github.com/imagemagick/imagemagick" target="_blank" rel="noopener" aria-label="GitHub"><svg xmlns="http://www.w3.org/2000/svg" class="navbar-nav-svg" viewBox="0 0 512 499.36" width="2%" height="2%" role="img" focusable="false"><title>GitHub</title><path fill="currentColor" fill-rule="evenodd" d="M256 0C114.64 0 0 114.61 0 256c0 113.09 73.34 209 175.08 242.9 12.8 2.35 17.47-5.56 17.47-12.34 0-6.08-.22-22.18-.35-43.54-71.2 15.49-86.2-34.34-86.2-34.34-11.64-29.57-28.42-37.45-28.42-37.45-23.27-15.84 1.73-15.55 1.73-15.55 25.69 1.81 39.21 26.38 39.21 26.38 22.84 39.12 59.92 27.82 74.5 21.27 2.33-16.54 8.94-27.82 16.25-34.22-56.84-6.43-116.6-28.43-116.6-126.49 0-27.95 10-50.8 26.35-68.69-2.63-6.48-11.42-32.5 2.51-67.75 0 0 21.49-6.88 70.4 26.24a242.65 242.65 0 0 1 128.18 0c48.87-33.13 70.33-26.24 70.33-26.24 14 35.25 5.18 61.27 2.55 67.75 16.41 17.9 26.31 40.75 26.31 68.69 0 98.35-59.85 120-116.88 126.32 9.19 7.9 17.38 23.53 17.38 47.41 0 34.22-.31 61.83-.31 70.23 0 6.85 4.61 14.81 17.6 12.31C438.72 464.97 512 369.08 512 256.02 512 114.62 397.37 0 256 0z"/></svg></a> •
273     <a href="https://twitter.com/imagemagick" target="_blank" rel="noopener" aria-label="Twitter"><svg xmlns="http://www.w3.org/2000/svg" class="navbar-nav-svg" viewBox="0 0 512 416.32" width="2%" height="2%" role="img" focusable="false"><title>Twitter</title><path fill="currentColor" d="M160.83 416.32c193.2 0 298.92-160.22 298.92-298.92 0-4.51 0-9-.2-13.52A214 214 0 0 0 512 49.38a212.93 212.93 0 0 1-60.44 16.6 105.7 105.7 0 0 0 46.3-58.19 209 209 0 0 1-66.79 25.37 105.09 105.09 0 0 0-181.73 71.91 116.12 116.12 0 0 0 2.66 24c-87.28-4.3-164.73-46.3-216.56-109.82A105.48 105.48 0 0 0 68 159.6a106.27 106.27 0 0 1-47.53-13.11v1.43a105.28 105.28 0 0 0 84.21 103.06 105.67 105.67 0 0 1-47.33 1.84 105.06 105.06 0 0 0 98.14 72.94A210.72 210.72 0 0 1 25 370.84a202.17 202.17 0 0 1-25-1.43 298.85 298.85 0 0 0 160.83 46.92"/></svg></a>
274    <br/>
275    <small>© 1999-2021 ImageMagick Studio LLC</small>
276    </div>
277  </footer>
278
279  <!-- Javascript assets -->
280  <script src="../../assets/magick.js" ></script>
281  </body>
282</html>
283