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,minimum-scale=1,initial-scale=1,shrink-to-fit=no" /> 10 <title>MagickCore, C API: Image View Methods @ ImageMagick</title> 11 <meta name="application-name" content="ImageMagick" /> 12 <meta name="description" content="Use ImageMagick to create, edit, compose, or convert bitmap images. You can resize your image, crop it, change its shades and colors, add captions, among other operations." /> 13 <meta name="application-url" content="https://imagemagick.org" /> 14 <meta name="generator" content="PHP" /> 15 <meta name="keywords" content="magickcore, c, api:, image, view, methods, ImageMagick, PerlMagick, image processing, image, photo, software, Magick++, OpenMP, convert" /> 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-2017 ImageMagick Studio LLC" /> 23 <meta name="distribution" content="Global" /> 24 <meta name="magick-serial" content="P131-S030410-R485315270133-P82224-A6668-G1245-1" /> 25 <meta name="google-site-verification" content="_bMOCDpkx9ZAzBwb2kF3PRHbfUUdFj2uO8Jd1AXArz4" /> 26 <link href="image-view.html" rel="canonical" /> 27 <link href="../../images/wand.png" rel="icon" /> 28 <link href="../../images/wand.ico" rel="shortcut icon" /> 29 <link href="../assets/magick.css" rel="stylesheet" /> 30 </head> 31 <body> 32 <header> 33 <nav class="navbar navbar-expand-md navbar-dark fixed-top bg-dark"> 34 <a class="navbar-brand" href="../../"><img class="d-block" id="icon" alt="ImageMagick" width="32" height="32" src="../../images/wand.ico"/></a> 35 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarsMagick" aria-controls="navbarsMagick" aria-expanded="false" aria-label="Toggle navigation"> 36 <span class="navbar-toggler-icon"></span> 37 </button> 38 39 <div class="navbar-collapse collapse" id="navbarsMagick" style=""> 40 <ul class="navbar-nav mr-auto"> 41 <li class="nav-item "> 42 <a class="nav-link" href="quantize.html">Home <span class="sr-only">(current)</span></a> 43 </li> 44 <li class="nav-item "> 45 <a class="nav-link" href="../../www/download.html">Download</a> 46 </li> 47 <li class="nav-item "> 48 <a class="nav-link" href="../../www/command-line-tools.html">Tools</a> 49 </li> 50 <li class="nav-item "> 51 <a class="nav-link" href="../../www/command-line-processing.html">Command-line</a> 52 </li> 53 <li class="nav-item "> 54 <a class="nav-link" href="../../www/resources.html">Resources</a> 55 </li> 56 <li class="nav-item "> 57 <a class="nav-link" href="../../www/develop.html">Develop</a> 58 </li> 59 <li class="nav-item"> 60 <a class="nav-link" target="_blank" href="https://imagemagick.org/discourse-server/">Community</a> 61 </li> 62 </ul> 63 <form class="form-inline my-2 my-lg-0" action="https://imagemagick.org/script/search.php"> 64 <input class="form-control mr-sm-2" type="text" name="q" placeholder="Search" aria-label="Search"> 65 <button class="btn btn-outline-success my-2 my-sm-0" type="submit" name="sa">Search</button> 66 </form> 67 </div> 68 </nav> 69 <div class="container"> 70 <script async="async" src="https://localhost/pagead/js/adsbygoogle.js"></script> <ins class="adsbygoogle" 71 style="display:block" 72 data-ad-client="ca-pub-3129977114552745" 73 data-ad-slot="6345125851" 74 data-ad-format="auto"></ins> 75 <script> 76 (adsbygoogle = window.adsbygoogle || []).push({}); 77 </script> 78 79 </div> 80 </header> 81 <main class="container"> 82 <div class="magick-template"> 83 <div class="magick-header"> 84 <p class="text-center"><a href="image-view.html#CloneImageView">CloneImageView</a> • <a href="image-view.html#DestroyImageView">DestroyImageView</a> • <a href="image-view.html#DuplexTransferImageViewIterator">DuplexTransferImageViewIterator</a> • <a href="image-view.html#GetImageViewAuthenticMetacontent">GetImageViewAuthenticMetacontent</a> • <a href="image-view.html#GetImageViewAuthenticPixels">GetImageViewAuthenticPixels</a> • <a href="image-view.html#GetImageViewException">GetImageViewException</a> • <a href="image-view.html#GetImageViewExtent">GetImageViewExtent</a> • <a href="image-view.html#GetImageViewImage">GetImageViewImage</a> • <a href="image-view.html#GetImageViewIterator">GetImageViewIterator</a> • <a href="image-view.html#GetImageViewVirtualMetacontent">GetImageViewVirtualMetacontent</a> • <a href="image-view.html#GetImageViewVirtualPixels">GetImageViewVirtualPixels</a> • <a href="image-view.html#IsImageView">IsImageView</a> • <a href="image-view.html#NewImageView">NewImageView</a> • <a href="image-view.html#NewImageViewRegion">NewImageViewRegion</a> • <a href="image-view.html#SetImageViewDescription">SetImageViewDescription</a> • <a href="image-view.html#SetImageViewIterator">SetImageViewIterator</a> • <a href="image-view.html#TransferImageViewIterator">TransferImageViewIterator</a> • <a href="image-view.html#UpdateImageViewIterator">UpdateImageViewIterator</a></p> 85 86 <h2><a href="../../api/MagickCore/image-view_8c.html" id="CloneImageView">CloneImageView</a></h2> 87 88 <p>CloneImageView() makes a copy of the specified image view.</p> 89 90 <p>The format of the CloneImageView method is:</p> 91 92 <pre class="text"> 93 ImageView *CloneImageView(const ImageView *image_view) 94 </pre> 95 96 <p>A description of each parameter follows:</p> 97 98 <dd> 99 </dd> 100 101 <dd> </dd> 102 <dl class="dl-horizontal"> 103 <dt>image_view</dt> 104 <dd>the image view. </dd> 105 106 <dd> </dd> 107 </dl> 108 <h2><a href="../../api/MagickCore/image-view_8c.html" id="DestroyImageView">DestroyImageView</a></h2> 109 110 <p>DestroyImageView() deallocates memory associated with a image view.</p> 111 112 <p>The format of the DestroyImageView method is:</p> 113 114 <pre class="text"> 115 ImageView *DestroyImageView(ImageView *image_view) 116 </pre> 117 118 <p>A description of each parameter follows:</p> 119 120 <dd> 121 </dd> 122 123 <dd> </dd> 124 <dl class="dl-horizontal"> 125 <dt>image_view</dt> 126 <dd>the image view. </dd> 127 128 <dd> </dd> 129 </dl> 130 <h2><a href="../../api/MagickCore/image-view_8c.html" id="DuplexTransferImageViewIterator">DuplexTransferImageViewIterator</a></h2> 131 132 <p>DuplexTransferImageViewIterator() iterates over three image views in parallel and calls your transfer method for each scanline of the view. The source and duplex pixel extent is not confined to the image canvas-- that is you can include negative offsets or widths or heights that exceed the image dimension. However, the destination image view is confined to the image canvas-- that is no negative offsets or widths or heights that exceed the image dimension are permitted.</p> 133 134 <p>The callback signature is:</p> 135 136 <pre class="text"> 137 MagickBooleanType DuplexTransferImageViewMethod(const ImageView *source, 138 const ImageView *duplex,ImageView *destination,const ssize_t y, 139 const int thread_id,void *context) 140 </pre> 141 142 <p>Use this pragma if the view is not single threaded:</p> 143 144 <pre class="text"> 145 #pragma omp critical 146 </pre> 147 148 <p>to define a section of code in your callback transfer method that must be executed by a single thread at a time.</p> 149 150 <p>The format of the DuplexTransferImageViewIterator method is:</p> 151 152 <pre class="text"> 153 MagickBooleanType DuplexTransferImageViewIterator(ImageView *source, 154 ImageView *duplex,ImageView *destination, 155 DuplexTransferImageViewMethod transfer,void *context) 156 </pre> 157 158 <p>A description of each parameter follows:</p> 159 160 <dd> 161 </dd> 162 163 <dd> </dd> 164 <dl class="dl-horizontal"> 165 <dt>source</dt> 166 <dd>the source image view. </dd> 167 168 <dd> </dd> 169 <dt>duplex</dt> 170 <dd>the duplex image view. </dd> 171 172 <dd> </dd> 173 <dt>destination</dt> 174 <dd>the destination image view. </dd> 175 176 <dd> </dd> 177 <dt>transfer</dt> 178 <dd>the transfer callback method. </dd> 179 180 <dd> </dd> 181 <dt>context</dt> 182 <dd>the user defined context. </dd> 183 184 <dd> </dd> 185 </dl> 186 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewAuthenticMetacontent">GetImageViewAuthenticMetacontent</a></h2> 187 188 <p>GetImageViewAuthenticMetacontent() returns the image view authentic meta-content.</p> 189 190 <p>The format of the GetImageViewAuthenticPixels method is:</p> 191 192 <pre class="text"> 193 void *GetImageViewAuthenticMetacontent( 194 const ImageView *image_view) 195 </pre> 196 197 <p>A description of each parameter follows:</p> 198 199 <dd> 200 </dd> 201 202 <dd> </dd> 203 <dl class="dl-horizontal"> 204 <dt>image_view</dt> 205 <dd>the image view. </dd> 206 207 <dd> </dd> 208 </dl> 209 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewAuthenticPixels">GetImageViewAuthenticPixels</a></h2> 210 211 <p>GetImageViewAuthenticPixels() returns the image view authentic pixels.</p> 212 213 <p>The format of the GetImageViewAuthenticPixels method is:</p> 214 215 <pre class="text"> 216 Quantum *GetImageViewAuthenticPixels(const ImageView *image_view) 217 </pre> 218 219 <p>A description of each parameter follows:</p> 220 221 <dd> 222 </dd> 223 224 <dd> </dd> 225 <dl class="dl-horizontal"> 226 <dt>image_view</dt> 227 <dd>the image view. </dd> 228 229 <dd> </dd> 230 </dl> 231 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewException">GetImageViewException</a></h2> 232 233 <p>GetImageViewException() returns the severity, reason, and description of any error that occurs when utilizing a image view.</p> 234 235 <p>The format of the GetImageViewException method is:</p> 236 237 <pre class="text"> 238 char *GetImageViewException(const PixelImage *image_view, 239 ExceptionType *severity) 240 </pre> 241 242 <p>A description of each parameter follows:</p> 243 244 <dd> 245 </dd> 246 247 <dd> </dd> 248 <dl class="dl-horizontal"> 249 <dt>image_view</dt> 250 <dd>the pixel image_view. </dd> 251 252 <dd> </dd> 253 <dt>severity</dt> 254 <dd>the severity of the error is returned here. </dd> 255 256 <dd> </dd> 257 </dl> 258 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewExtent">GetImageViewExtent</a></h2> 259 260 <p>GetImageViewExtent() returns the image view extent.</p> 261 262 <p>The format of the GetImageViewExtent method is:</p> 263 264 <pre class="text"> 265 RectangleInfo GetImageViewExtent(const ImageView *image_view) 266 </pre> 267 268 <p>A description of each parameter follows:</p> 269 270 <dd> 271 </dd> 272 273 <dd> </dd> 274 <dl class="dl-horizontal"> 275 <dt>image_view</dt> 276 <dd>the image view. </dd> 277 278 <dd> </dd> 279 </dl> 280 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewImage">GetImageViewImage</a></h2> 281 282 <p>GetImageViewImage() returns the image associated with the image view.</p> 283 284 <p>The format of the GetImageViewImage method is:</p> 285 286 <pre class="text"> 287 MagickCore *GetImageViewImage(const ImageView *image_view) 288 </pre> 289 290 <p>A description of each parameter follows:</p> 291 292 <dd> 293 </dd> 294 295 <dd> </dd> 296 <dl class="dl-horizontal"> 297 <dt>image_view</dt> 298 <dd>the image view. </dd> 299 300 <dd> </dd> 301 </dl> 302 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewIterator">GetImageViewIterator</a></h2> 303 304 <p>GetImageViewIterator() iterates over the image view in parallel and calls your get method for each scanline of the view. The pixel extent is not confined to the image canvas-- that is you can include negative offsets or widths or heights that exceed the image dimension. Any updates to the pixels in your callback are ignored.</p> 305 306 <p>The callback signature is:</p> 307 308 <pre class="text"> 309 MagickBooleanType GetImageViewMethod(const ImageView *source, 310 const ssize_t y,const int thread_id,void *context) 311 </pre> 312 313 <p>Use this pragma if the view is not single threaded:</p> 314 315 <pre class="text"> 316 #pragma omp critical 317 </pre> 318 319 <p>to define a section of code in your callback get method that must be executed by a single thread at a time.</p> 320 321 <p>The format of the GetImageViewIterator method is:</p> 322 323 <pre class="text"> 324 MagickBooleanType GetImageViewIterator(ImageView *source, 325 GetImageViewMethod get,void *context) 326 </pre> 327 328 <p>A description of each parameter follows:</p> 329 330 <dd> 331 </dd> 332 333 <dd> </dd> 334 <dl class="dl-horizontal"> 335 <dt>source</dt> 336 <dd>the source image view. </dd> 337 338 <dd> </dd> 339 <dt>get</dt> 340 <dd>the get callback method. </dd> 341 342 <dd> </dd> 343 <dt>context</dt> 344 <dd>the user defined context. </dd> 345 346 <dd> </dd> 347 </dl> 348 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewVirtualMetacontent">GetImageViewVirtualMetacontent</a></h2> 349 350 <p>GetImageViewVirtualMetacontent() returns the image view virtual meta-content.</p> 351 352 <p>The format of the GetImageViewVirtualMetacontent method is:</p> 353 354 <pre class="text"> 355 const void *GetImageViewVirtualMetacontent( 356 const ImageView *image_view) 357 </pre> 358 359 <p>A description of each parameter follows:</p> 360 361 <dd> 362 </dd> 363 364 <dd> </dd> 365 <dl class="dl-horizontal"> 366 <dt>image_view</dt> 367 <dd>the image view. </dd> 368 369 <dd> </dd> 370 </dl> 371 <h2><a href="../../api/MagickCore/image-view_8c.html" id="GetImageViewVirtualPixels">GetImageViewVirtualPixels</a></h2> 372 373 <p>GetImageViewVirtualPixels() returns the image view virtual pixels.</p> 374 375 <p>The format of the GetImageViewVirtualPixels method is:</p> 376 377 <pre class="text"> 378 const Quantum *GetImageViewVirtualPixels(const ImageView *image_view) 379 </pre> 380 381 <p>A description of each parameter follows:</p> 382 383 <dd> 384 </dd> 385 386 <dd> </dd> 387 <dl class="dl-horizontal"> 388 <dt>image_view</dt> 389 <dd>the image view. </dd> 390 391 <dd> </dd> 392 </dl> 393 <h2><a href="../../api/MagickCore/image-view_8c.html" id="IsImageView">IsImageView</a></h2> 394 395 <p>IsImageView() returns MagickTrue if the the parameter is verified as a image view object.</p> 396 397 <p>The format of the IsImageView method is:</p> 398 399 <pre class="text"> 400 MagickBooleanType IsImageView(const ImageView *image_view) 401 </pre> 402 403 <p>A description of each parameter follows:</p> 404 405 <dd> 406 </dd> 407 408 <dd> </dd> 409 <dl class="dl-horizontal"> 410 <dt>image_view</dt> 411 <dd>the image view. </dd> 412 413 <dd> </dd> 414 </dl> 415 <h2><a href="../../api/MagickCore/image-view_8c.html" id="NewImageView">NewImageView</a></h2> 416 417 <p>NewImageView() returns a image view required for all other methods in the Image View API.</p> 418 419 <p>The format of the NewImageView method is:</p> 420 421 <pre class="text"> 422 ImageView *NewImageView(MagickCore *wand,ExceptionInfo *exception) 423 </pre> 424 425 <p>A description of each parameter follows:</p> 426 427 <dd> 428 </dd> 429 430 <dd> </dd> 431 <dl class="dl-horizontal"> 432 <dt>image</dt> 433 <dd>the image. </dd> 434 435 <dd> </dd> 436 <dt>exception</dt> 437 <dd>return any errors or warnings in this structure. </dd> 438 439 <dd> </dd> 440 </dl> 441 <h2><a href="../../api/MagickCore/image-view_8c.html" id="NewImageViewRegion">NewImageViewRegion</a></h2> 442 443 <p>NewImageViewRegion() returns a image view required for all other methods in the Image View API.</p> 444 445 <p>The format of the NewImageViewRegion method is:</p> 446 447 <pre class="text"> 448 ImageView *NewImageViewRegion(MagickCore *wand,const ssize_t x, 449 const ssize_t y,const size_t width,const size_t height, 450 ExceptionInfo *exception) 451 </pre> 452 453 <p>A description of each parameter follows:</p> 454 455 <dd> 456 </dd> 457 458 <dd> </dd> 459 <dl class="dl-horizontal"> 460 <dt>wand</dt> 461 <dd>the magick wand. </dd> 462 463 <dd> </dd> 464 <dt>x,y,columns,rows</dt> 465 <dd> These values define the perimeter of a extent of pixel_wands view. </dd> 466 467 <dd> </dd> 468 <dt>exception</dt> 469 <dd>return any errors or warnings in this structure. </dd> 470 471 <dd> </dd> 472 </dl> 473 <h2><a href="../../api/MagickCore/image-view_8c.html" id="SetImageViewDescription">SetImageViewDescription</a></h2> 474 475 <p>SetImageViewDescription() associates a description with an image view.</p> 476 477 <p>The format of the SetImageViewDescription method is:</p> 478 479 <pre class="text"> 480 void SetImageViewDescription(ImageView *image_view, 481 const char *description) 482 </pre> 483 484 <p>A description of each parameter follows:</p> 485 486 <dd> 487 </dd> 488 489 <dd> </dd> 490 <dl class="dl-horizontal"> 491 <dt>image_view</dt> 492 <dd>the image view. </dd> 493 494 <dd> </dd> 495 <dt>description</dt> 496 <dd>the image view description. </dd> 497 498 <dd> </dd> 499 </dl> 500 <h2><a href="../../api/MagickCore/image-view_8c.html" id="SetImageViewIterator">SetImageViewIterator</a></h2> 501 502 <p>SetImageViewIterator() iterates over the image view in parallel and calls your set method for each scanline of the view. The pixel extent is confined to the image canvas-- that is no negative offsets or widths or heights that exceed the image dimension. The pixels are initiallly undefined and any settings you make in the callback method are automagically synced back to your image.</p> 503 504 <p>The callback signature is:</p> 505 506 <pre class="text"> 507 MagickBooleanType SetImageViewMethod(ImageView *destination, 508 const ssize_t y,const int thread_id,void *context) 509 </pre> 510 511 <p>Use this pragma if the view is not single threaded:</p> 512 513 <pre class="text"> 514 #pragma omp critical 515 </pre> 516 517 <p>to define a section of code in your callback set method that must be executed by a single thread at a time.</p> 518 519 <p>The format of the SetImageViewIterator method is:</p> 520 521 <pre class="text"> 522 MagickBooleanType SetImageViewIterator(ImageView *destination, 523 SetImageViewMethod set,void *context) 524 </pre> 525 526 <p>A description of each parameter follows:</p> 527 528 <dd> 529 </dd> 530 531 <dd> </dd> 532 <dl class="dl-horizontal"> 533 <dt>destination</dt> 534 <dd>the image view. </dd> 535 536 <dd> </dd> 537 <dt>set</dt> 538 <dd>the set callback method. </dd> 539 540 <dd> </dd> 541 <dt>context</dt> 542 <dd>the user defined context. </dd> 543 544 <dd> </dd> 545 </dl> 546 <h2><a href="../../api/MagickCore/image-view_8c.html" id="TransferImageViewIterator">TransferImageViewIterator</a></h2> 547 548 <p>TransferImageViewIterator() iterates over two image views in parallel and calls your transfer method for each scanline of the view. The source pixel extent is not confined to the image canvas-- that is you can include negative offsets or widths or heights that exceed the image dimension. However, the destination image view is confined to the image canvas-- that is no negative offsets or widths or heights that exceed the image dimension are permitted.</p> 549 550 <p>The callback signature is:</p> 551 552 <pre class="text"> 553 MagickBooleanType TransferImageViewMethod(const ImageView *source, 554 ImageView *destination,const ssize_t y,const int thread_id, 555 void *context) 556 </pre> 557 558 <p>Use this pragma if the view is not single threaded:</p> 559 560 <pre class="text"> 561 #pragma omp critical 562 </pre> 563 564 <p>to define a section of code in your callback transfer method that must be executed by a single thread at a time.</p> 565 566 <p>The format of the TransferImageViewIterator method is:</p> 567 568 <pre class="text"> 569 MagickBooleanType TransferImageViewIterator(ImageView *source, 570 ImageView *destination,TransferImageViewMethod transfer,void *context) 571 </pre> 572 573 <p>A description of each parameter follows:</p> 574 575 <dd> 576 </dd> 577 578 <dd> </dd> 579 <dl class="dl-horizontal"> 580 <dt>source</dt> 581 <dd>the source image view. </dd> 582 583 <dd> </dd> 584 <dt>destination</dt> 585 <dd>the destination image view. </dd> 586 587 <dd> </dd> 588 <dt>transfer</dt> 589 <dd>the transfer callback method. </dd> 590 591 <dd> </dd> 592 <dt>context</dt> 593 <dd>the user defined context. </dd> 594 595 <dd> </dd> 596 </dl> 597 <h2><a href="../../api/MagickCore/image-view_8c.html" id="UpdateImageViewIterator">UpdateImageViewIterator</a></h2> 598 599 <p>UpdateImageViewIterator() iterates over the image view in parallel and calls your update method for each scanline of the view. The pixel extent is confined to the image canvas-- that is no negative offsets or widths or heights that exceed the image dimension are permitted. Updates to pixels in your callback are automagically synced back to the image.</p> 600 601 <p>The callback signature is:</p> 602 603 <pre class="text"> 604 MagickBooleanType UpdateImageViewMethod(ImageView *source, 605 const ssize_t y,const int thread_id,void *context) 606 </pre> 607 608 <p>Use this pragma if the view is not single threaded:</p> 609 610 <pre class="text"> 611 #pragma omp critical 612 </pre> 613 614 <p>to define a section of code in your callback update method that must be executed by a single thread at a time.</p> 615 616 <p>The format of the UpdateImageViewIterator method is:</p> 617 618 <pre class="text"> 619 MagickBooleanType UpdateImageViewIterator(ImageView *source, 620 UpdateImageViewMethod update,void *context) 621 </pre> 622 623 <p>A description of each parameter follows:</p> 624 625 <dd> 626 </dd> 627 628 <dd> </dd> 629 <dl class="dl-horizontal"> 630 <dt>source</dt> 631 <dd>the source image view. </dd> 632 633 <dd> </dd> 634 <dt>update</dt> 635 <dd>the update callback method. </dd> 636 637 <dd> </dd> 638 <dt>context</dt> 639 <dd>the user defined context. </dd> 640 641 <dd> </dd> 642 </dl> 643 </div> 644 </div> 645 </main><!-- /.container --> 646 <footer class="magick-footer"> 647 <p><a href="../../www/security-policy.html">Security</a> 648 <a href="../../www/architecture.html">Architecture</a> 649 <a href="../../www/links.html">Related</a> 650 <a href="../../www/sitemap.html">Sitemap</a> 651 652 <a href="image-view.html#"><img class="d-inline" id="wand" alt="And Now a Touch of Magick" width="16" height="16" src="../../images/wand.ico"/></a> 653 654 <a href="http://pgp.mit.edu/pks/lookup?op=get&search=0x89AB63D48277377A">Public Key</a> 655 <a href="../../www/support.html">Donate</a> 656 <a href="../../www/contact.html">Contact Us</a> 657 <br/> 658 <small> 1999-2019 ImageMagick Studio LLC</small></p> 659 </footer> 660 661 <!-- Javascript assets --> 662 <script src="../assets/magick.js" crossorigin="anonymous"></script> 663 <script>window.jQuery || document.write('<script src="https://localhost/ajax/libs/jquery/3.3.1/jquery.min.js"><\/script>')</script> 664 </body> 665 </html> 666 <!-- Magick Cache 31st December 2018 07:45 -->