|
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 |
}
|