multichan.c 825 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. #include <u.h>
  2. #include <libc.h>
  3. #include <draw.h>
  4. #include <memdraw.h>
  5. #include <bio.h>
  6. #include "imagefile.h"
  7. /* Separate colors, if not a grey scale or bitmap, into one byte per color per pixel, no alpha or X */
  8. /* Result is GREY[1248] or RGB24 */
  9. static
  10. int
  11. notrans(ulong chan)
  12. {
  13. switch(chan){
  14. case GREY1:
  15. case GREY2:
  16. case GREY4:
  17. case GREY8:
  18. case RGB24:
  19. return 1;
  20. }
  21. return 0;
  22. }
  23. Image*
  24. multichan(Image *i)
  25. {
  26. Image *ni;
  27. if(notrans(i->chan))
  28. return i;
  29. ni = allocimage(display, i->r, RGB24, 0, DNofill);
  30. if(ni == nil)
  31. return ni;
  32. draw(ni, ni->r, i, nil, i->r.min);
  33. return ni;
  34. }
  35. Memimage*
  36. memmultichan(Memimage *i)
  37. {
  38. Memimage *ni;
  39. if(notrans(i->chan))
  40. return i;
  41. ni = allocmemimage(i->r, RGB24);
  42. if(ni == nil)
  43. return ni;
  44. memimagedraw(ni, ni->r, i, i->r.min, nil, i->r.min, S);
  45. return ni;
  46. }