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> • <a href="histogram.html#IdentifyPaletteImage">IdentifyPaletteImage</a> • <a href="histogram.html#IsHistogramImage">IsHistogramImage</a> • <a href="histogram.html#IsPaletteImage">IsPaletteImage</a> • <a href="histogram.html#MinMaxStretchImage">MinMaxStretchImage</a> • <a href="histogram.html#GetNumberColors">GetNumberColors</a> • <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&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