25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

context.c 3.6 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. /*
  2. * libpipi Proper image processing implementation library
  3. * Copyright (c) 2004-2008 Sam Hocevar <sam@zoy.org>
  4. * All Rights Reserved
  5. *
  6. * $Id$
  7. *
  8. * This library is free software. It comes without any warranty, to
  9. * the extent permitted by applicable law. You can redistribute it
  10. * and/or modify it under the terms of the Do What The Fuck You Want
  11. * To Public License, Version 2, as published by Sam Hocevar. See
  12. * http://sam.zoy.org/wtfpl/COPYING for more details.
  13. */
  14. /*
  15. * context.c: processing stack handling routines
  16. */
  17. #include "config.h"
  18. #include "common.h"
  19. #include <stdio.h>
  20. #include <stdlib.h>
  21. #include <stdarg.h>
  22. #include <string.h>
  23. #include "pipi.h"
  24. #include "pipi_internals.h"
  25. pipi_context_t *pipi_create_context()
  26. {
  27. pipi_context_t *ret;
  28. ret = malloc(sizeof(pipi_context_t));
  29. memset(ret, 0, sizeof(pipi_context_t));
  30. return ret;
  31. }
  32. void pipi_destroy_context(pipi_context_t *ctx)
  33. {
  34. free(ctx);
  35. }
  36. int pipi_command(pipi_context_t *ctx, char const *cmd, ...)
  37. {
  38. if(!strcmp(cmd, "load"))
  39. {
  40. char const *file;
  41. va_list ap;
  42. va_start(ap, cmd);
  43. file = va_arg(ap, char const *);
  44. va_end(ap);
  45. ctx->images[ctx->nimages] = pipi_load(file);
  46. if(ctx->images[ctx->nimages] == NULL)
  47. return -1;
  48. ctx->nimages++;
  49. }
  50. else if(!strcmp(cmd, "save"))
  51. {
  52. char const *file;
  53. va_list ap;
  54. if(ctx->nimages <= 0)
  55. return -1;
  56. ctx->nimages--;
  57. va_start(ap, cmd);
  58. file = va_arg(ap, char const *);
  59. va_end(ap);
  60. pipi_save(ctx->images[ctx->nimages], file);
  61. pipi_free(ctx->images[ctx->nimages]);
  62. }
  63. else if(!strcmp(cmd, "dither"))
  64. {
  65. pipi_image_t *src, *dst;
  66. char const *method;
  67. va_list ap;
  68. if(ctx->nimages <= 0)
  69. return -1;
  70. va_start(ap, cmd);
  71. method = va_arg(ap, char const *);
  72. va_end(ap);
  73. src = ctx->images[ctx->nimages - 1];
  74. dst = NULL;
  75. if(!strcmp(method, "fs"))
  76. dst = pipi_dither_floydsteinberg(src, 0);
  77. else if(!strcmp(method, "sfs"))
  78. dst = pipi_dither_floydsteinberg(src, 1);
  79. else if(!strcmp(method, "ost"))
  80. dst = pipi_dither_ostromoukhov(src, 0);
  81. else if(!strcmp(method, "sost"))
  82. dst = pipi_dither_ostromoukhov(src, 1);
  83. else if(!strcmp(method, "ordered"))
  84. dst = pipi_dither_ordered(src);
  85. else if(!strcmp(method, "random"))
  86. dst = pipi_dither_random(src);
  87. else if(!strcmp(method, "dbs"))
  88. dst = pipi_dither_dbs(src);
  89. if(dst == NULL)
  90. return -1;
  91. pipi_free(src);
  92. ctx->images[ctx->nimages - 1] = dst;
  93. }
  94. else if(!strcmp(cmd, "blur"))
  95. {
  96. pipi_image_t *src, *dst;
  97. char const *arg;
  98. va_list ap;
  99. if(ctx->nimages <= 0)
  100. return -1;
  101. va_start(ap, cmd);
  102. arg = va_arg(ap, char const *);
  103. va_end(ap);
  104. src = ctx->images[ctx->nimages - 1];
  105. dst = pipi_gaussian_blur(src, atoi(arg));
  106. if(dst == NULL)
  107. return -1;
  108. pipi_free(src);
  109. ctx->images[ctx->nimages - 1] = dst;
  110. }
  111. else if(!strcmp(cmd, "free"))
  112. {
  113. if(ctx->nimages <= 0)
  114. return -1;
  115. ctx->nimages--;
  116. pipi_free(ctx->images[ctx->nimages]);
  117. }
  118. else if(!strcmp(cmd, "dup"))
  119. {
  120. if(ctx->nimages <= 0)
  121. return -1;
  122. ctx->images[ctx->nimages] = pipi_copy(ctx->images[ctx->nimages - 1]);
  123. ctx->nimages++;
  124. }
  125. else
  126. {
  127. return -1;
  128. }
  129. return 0;
  130. }