Blame support/cltkImg.c

Packit bd2e5d
/***********************************************************************/
Packit bd2e5d
/*                                                                     */
Packit bd2e5d
/*                 MLTk, Tcl/Tk interface of OCaml                     */
Packit bd2e5d
/*                                                                     */
Packit bd2e5d
/*    Francois Rouaix, Francois Pessaux, Jun Furuse and Pierre Weis    */
Packit bd2e5d
/*               projet Cristal, INRIA Rocquencourt                    */
Packit bd2e5d
/*            Jacques Garrigue, Kyoto University RIMS                  */
Packit bd2e5d
/*                                                                     */
Packit bd2e5d
/*  Copyright 2002 Institut National de Recherche en Informatique et   */
Packit bd2e5d
/*  en Automatique and Kyoto University.  All rights reserved.         */
Packit bd2e5d
/*  This file is distributed under the terms of the GNU Library        */
Packit bd2e5d
/*  General Public License, with the special exception on linking      */
Packit bd2e5d
/*  described in file LICENSE found in the OCaml source tree.          */
Packit bd2e5d
/*                                                                     */
Packit bd2e5d
/***********************************************************************/
Packit bd2e5d
#include <string.h>
Packit bd2e5d
#include <tcl.h>
Packit bd2e5d
#include <tk.h>
Packit bd2e5d
#include <mlvalues.h>
Packit bd2e5d
#include <memory.h>
Packit bd2e5d
#include <alloc.h>
Packit bd2e5d
#include "camltk.h"
Packit bd2e5d
Packit bd2e5d
/*
Packit bd2e5d
 * Pixmap manipulation from OCaml : get the pixmap from an arbitrary photo
Packit bd2e5d
 * image, and put it back in some (possibly other) image.
Packit bd2e5d
 * TODO: other blits
Packit bd2e5d
 * We use the same format of "internal" pixmap data as in Tk, that is
Packit bd2e5d
 * 24 bits per pixel
Packit bd2e5d
 */
Packit bd2e5d
Packit bd2e5d
CAMLprim value camltk_getimgdata (value imgname) /* ML */
Packit bd2e5d
{
Packit bd2e5d
  CAMLparam1(imgname);
Packit bd2e5d
  CAMLlocal1(res);
Packit bd2e5d
  Tk_PhotoHandle ph;
Packit bd2e5d
  Tk_PhotoImageBlock pib;
Packit bd2e5d
  int code,size;
Packit bd2e5d
Packit bd2e5d
#if (TK_MAJOR_VERSION < 8)
Packit bd2e5d
  if (NULL == (ph = Tk_FindPhoto(String_val(imgname))))
Packit bd2e5d
    tk_error("no such image");
Packit bd2e5d
#else
Packit bd2e5d
  if (NULL == (ph = Tk_FindPhoto(cltclinterp, String_val(imgname))))
Packit bd2e5d
    tk_error("no such image");
Packit bd2e5d
#endif
Packit bd2e5d
Packit bd2e5d
  code = Tk_PhotoGetImage(ph,&pib;; /* never fails ? */
Packit bd2e5d
  (void) code;
Packit bd2e5d
  size = pib.width * pib.height * pib.pixelSize;
Packit bd2e5d
  res = caml_alloc_string(size);
Packit bd2e5d
Packit bd2e5d
  /* no holes, default format ? */
Packit bd2e5d
  if ((pib.pixelSize == 3) &&
Packit bd2e5d
      (pib.pitch == (pib.width * pib.pixelSize)) &&
Packit bd2e5d
      (pib.offset[0] == 0) &&
Packit bd2e5d
      (pib.offset[1] == 1) &&
Packit bd2e5d
      (pib.offset[2] == 2)) {
Packit bd2e5d
    memcpy(pib.pixelPtr, String_val(res),size);
Packit bd2e5d
    CAMLreturn(res);
Packit bd2e5d
  } else {
Packit bd2e5d
    int y;                      /* varies from 0 to height - 1 */
Packit bd2e5d
    int yoffs = 0;              /* byte offset of line in src */
Packit bd2e5d
    int yidx = 0;               /* byte offset of line in dst */
Packit bd2e5d
    for (y=0; y
Packit bd2e5d
      int x;                    /* varies from 0 to width - 1 */
Packit bd2e5d
      int xoffs = yoffs;        /* byte offset of pxl in src */
Packit bd2e5d
      int xidx = yidx;          /* byte offset of pxl in dst */
Packit bd2e5d
      for (x=0; x
Packit bd2e5d
        Byte(res, xidx) = pib.pixelPtr[xoffs+pib.offset[0]];
Packit bd2e5d
        Byte(res, xidx + 1) = pib.pixelPtr[xoffs+pib.offset[1]];
Packit bd2e5d
        Byte(res, xidx + 2) = pib.pixelPtr[xoffs+pib.offset[2]];
Packit bd2e5d
      };
Packit bd2e5d
    }
Packit bd2e5d
    CAMLreturn(res);
Packit bd2e5d
  }
Packit bd2e5d
}
Packit bd2e5d
Packit bd2e5d
CAMLprim value
Packit bd2e5d
camltk_setimgdata_native (value imgname, value pixmap, value x, value y,
Packit bd2e5d
                   value w, value h) /* ML */
Packit bd2e5d
{
Packit bd2e5d
  Tk_PhotoHandle ph;
Packit bd2e5d
  Tk_PhotoImageBlock pib;
Packit bd2e5d
Packit bd2e5d
#if (TK_MAJOR_VERSION < 8)
Packit bd2e5d
  if (NULL == (ph = Tk_FindPhoto(String_val(imgname))))
Packit bd2e5d
    tk_error("no such image");
Packit bd2e5d
#else
Packit bd2e5d
  if (NULL == (ph = Tk_FindPhoto(cltclinterp, String_val(imgname))))
Packit bd2e5d
    tk_error("no such image");
Packit bd2e5d
#endif
Packit bd2e5d
Packit bd2e5d
  pib.pixelPtr = (unsigned char *)String_val(pixmap);
Packit bd2e5d
  pib.width = Int_val(w);
Packit bd2e5d
  pib.height = Int_val(h);
Packit bd2e5d
  pib.pitch = pib.width * 3;
Packit bd2e5d
  pib.pixelSize = 3;
Packit bd2e5d
  pib.offset[0] = 0;
Packit bd2e5d
  pib.offset[1] = 1;
Packit bd2e5d
  pib.offset[2] = 2;
Packit bd2e5d
  Tk_PhotoPutBlock(
Packit bd2e5d
#if (TK_MAJOR_VERSION == 8 && TK_MINOR_VERSION >= 5 || TK_MAJOR_VERSION > 8)
Packit bd2e5d
        NULL,
Packit bd2e5d
#endif
Packit bd2e5d
ph,&pib,Int_val(x),Int_val(y),Int_val(w),Int_val(h)
Packit bd2e5d
#if (TK_MAJOR_VERSION == 8 && TK_MINOR_VERSION >= 4 || TK_MAJOR_VERSION > 8)
Packit bd2e5d
                   , TK_PHOTO_COMPOSITE_SET
Packit bd2e5d
#endif
Packit bd2e5d
    );
Packit bd2e5d
  return Val_int(0);
Packit bd2e5d
}
Packit bd2e5d
Packit bd2e5d
CAMLprim value camltk_setimgdata_bytecode(argv,argn)
Packit bd2e5d
     value *argv;
Packit bd2e5d
     int argn;
Packit bd2e5d
{
Packit bd2e5d
  return camltk_setimgdata_native(argv[0], argv[1], argv[2], argv[3],
Packit bd2e5d
                                  argv[4], argv[5]);
Packit bd2e5d
}