Compare commits
3 Commits
2c1687f82b
...
d23a35849a
Author | SHA1 | Date | |
---|---|---|---|
|
d23a35849a | ||
|
82ffe1c2cc | ||
|
0a482a7316 |
@ -3,7 +3,7 @@
|
||||
Avec toutes ces fonctions disponibles et `grabvidseq`, nous
|
||||
savons faire des images **floues**. L'étape suivante, les plus
|
||||
pervers d'entre vous le savent déja, est celle de la création
|
||||
de **films flous** dans le domaine spacio-temporel.
|
||||
de **films flous** dans le domaine spatio-temporel.
|
||||
|
||||
À l'heure actuelle, il y a plusieurs programmes distincts. Le premier
|
||||
(fonderie) fait une moyenne mobile sur N images consécutives,
|
||||
|
@ -21,6 +21,38 @@
|
||||
*/
|
||||
extern int verbosity;
|
||||
|
||||
/* -------------------------------------------------------------- */
|
||||
/*
|
||||
* nouveau Sun Jul 16 07:37:22 UTC 2023
|
||||
*/
|
||||
int poke_sup_rb_g(FloatImg *src, FloatImg *dst)
|
||||
{
|
||||
int idx, nbpix, foo;
|
||||
|
||||
#if DEBUG_LEVEL
|
||||
fprintf(stderr, ">>> %s ( %p %p )\n", __func__, src, dst);
|
||||
#endif
|
||||
|
||||
if ( (foo=fimg_images_not_compatible(src, dst)) )
|
||||
{
|
||||
fprintf(stderr, "%s: no compat %d\n", __func__, foo);
|
||||
return foo;
|
||||
}
|
||||
|
||||
nbpix = src->width * src->height;
|
||||
fprintf(stderr, "%s work on %d pixels\n", __func__, nbpix);
|
||||
|
||||
for (idx=0; idx<nbpix; idx++) {
|
||||
dst->R[idx] = src->R[idx];
|
||||
dst->B[idx] = src->B[idx];
|
||||
if (dst->R[idx] > dst->B[idx])
|
||||
dst->G[idx] = dst->R[idx];
|
||||
else
|
||||
dst->G[idx] = dst->B[idx];
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
/* -------------------------------------------------------------- */
|
||||
/* nouveau 14 mai 2022 rue Ernest Renan */
|
||||
|
||||
|
@ -7,6 +7,7 @@ int graylevel2popcolors(FloatImg *src, FloatImg *dst, int k);
|
||||
|
||||
int incrustation_vignette(FloatImg *src, FloatImg *dst, int k);
|
||||
|
||||
int poke_sup_rb_g(FloatImg *src, FloatImg *dst);
|
||||
|
||||
int trinitron(FloatImg *pimg, int notused);
|
||||
|
||||
|
16
Fonderie/t.c
16
Fonderie/t.c
@ -40,7 +40,7 @@ double debut, fin;
|
||||
|
||||
foo = fimg_create_from_dump(fIname, &image);
|
||||
if (foo) {
|
||||
fprintf(stderr, "err %d create image\n", foo);
|
||||
fprintf(stderr, "%s: err %d create from dump\n", __func__, foo);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
@ -73,8 +73,6 @@ return 0;
|
||||
|
||||
foo = essayer_single("capture/???42.fimg", "/tmp/x8/", STK);
|
||||
fprintf(stderr, "essayer single -> %d\n", foo);
|
||||
|
||||
|
||||
*/
|
||||
int essayer_single(char *globpattern, char *destdir, int chain)
|
||||
{
|
||||
@ -161,14 +159,14 @@ puts("\t-s\tdo single test");
|
||||
exit(0);
|
||||
}
|
||||
/* ----------------------------------------------------------- */
|
||||
int experiment(void)
|
||||
int experiment(char *fname)
|
||||
{
|
||||
int foo;
|
||||
FloatImg image, dest;
|
||||
|
||||
fprintf(stderr, "--------- EXPERIMENT ------------\n");
|
||||
fprintf(stderr, "----- EXPERIMENT on '%s' -----\n", fname);
|
||||
|
||||
foo = fimg_create_from_dump("mire.fimg", &image);
|
||||
foo = fimg_create_from_dump(fname, &image);
|
||||
if (foo) {
|
||||
fprintf(stderr, "%s: err %d on create_from_dump\n",
|
||||
__func__, foo);
|
||||
@ -177,8 +175,8 @@ if (foo) {
|
||||
|
||||
foo = fimg_clone(&image, &dest, 0);
|
||||
|
||||
foo = graylevel2popcolors(&image, &dest, 0);
|
||||
fprintf(stderr, "POP COLOR- -> %d\n", foo);
|
||||
foo = poke_sup_rb_g(&image, &dest);
|
||||
fprintf(stderr, "poke sup rb g --> %d\n", foo);
|
||||
|
||||
fimg_export_picture(&dest, "foo.png", 0);
|
||||
|
||||
@ -230,7 +228,7 @@ if (foo) {
|
||||
}
|
||||
|
||||
if (do_xper) {
|
||||
experiment();
|
||||
experiment(infile);
|
||||
return 0;
|
||||
}
|
||||
if (do_single) {
|
||||
|
@ -53,6 +53,8 @@
|
||||
|
||||
\section*{Une image flottante ?}
|
||||
|
||||
\textsl{Back in a far past part of history.}
|
||||
|
||||
\textsl{Mais de quoi parle-t-on exactement ?}
|
||||
|
||||
% XXX XXX XXX\vspace{1em}
|
||||
@ -79,7 +81,12 @@ IRC de \textsl{libera.chat}.
|
||||
|
||||
\textbf{Attention !} ce document commence par une bonne rafale
|
||||
de technique parfois \textsl{hardue}\footnote{hard + ardue = private
|
||||
joke Usenet}, avec des pointeurs dedans.
|
||||
joke Usenet}, avec des pointeurs dedans, mais vous êtes déja
|
||||
au courant.
|
||||
Le pointeur, c'est bien, c'est comme le doigt sur les écrans
|
||||
de zombiephones, ça sert juste à dire «~C'est là !~», c'est
|
||||
donc gravement utile, mais parfois, le doigt glisse.
|
||||
Et là, tout peut arriver.
|
||||
Vous avez parfaitement le droit de sauter directement à
|
||||
la page \pageref{outils} pour quelque chose de plus concret.
|
||||
|
||||
@ -510,7 +517,7 @@ Si la valeur retournée est différente de 0, c'est que quelque
|
||||
chose s'est probablement mal passé.
|
||||
Certains messages sont parfois explicites. Mais parfois non.
|
||||
Quand aux valeurs retournées en cas d'erreur, c'est le désordre
|
||||
intégral.
|
||||
intégral\footnote{Un vrai désastre, même...}.
|
||||
|
||||
% _________
|
||||
|
||||
@ -1396,7 +1403,7 @@ le premier pouvant salement brotcher une image, et le second capable de
|
||||
mélanger harmonieusement deux images, la balance est équilibrée.
|
||||
|
||||
Il s'agit donc d'un petit programme écrit en Bash\index{bash}, un langage
|
||||
dont la connaissance est, pour moi, indispendable à qui veut faire des
|
||||
dont la connaissance est, pour moi, indispensable à qui veut faire des
|
||||
images kitchies\index{kitchy}. Mais ne vous inquiétez pas, c'est en
|
||||
fait assez simple à comprendre. Et comprendre, c'est apprendre.
|
||||
|
||||
@ -1625,10 +1632,12 @@ devez mettre ce bout de XML\index{XML} dans le fichier
|
||||
\end{lstlisting}
|
||||
|
||||
C'est juste un hack rapide, qui ne fonctionne pas très bien avec
|
||||
d'autres commande de IM, comme identify, qui a tendance à
|
||||
d'autres commande de IM, comme \texttt{identify}\index{identify},
|
||||
qui a tendance à
|
||||
raconter un peu n'importe quoi, puisqu'elle se base sur le
|
||||
résultat de la conversion.
|
||||
Je compte donc sur le bouquin de \textsl{Brunus} pour avancer\dots
|
||||
Je compte donc sur le bouquin de \textsl{Brunus}\index{Brunus}
|
||||
pour avancer\dots
|
||||
|
||||
\subsection{Gimp}\index{Gimp}
|
||||
|
||||
@ -1662,7 +1671,7 @@ Bon courage pour toutes les explorer, voire même juste les comprendre.
|
||||
Il y a d'autres logiciels pour lesquels écrire une fonction d'importation
|
||||
serait bien~: \textsl{Geeqie}, un visualiseur d'image fort pratique, ou
|
||||
\textsl{Krita} qui semble avoir les faveurs de
|
||||
dessinateurs de talent\footnote{Oui, David, c'est à toi que je pense.}.
|
||||
dessinateurs de talent.
|
||||
Ce qui nous conduit à une question importante~: quels sont les logiciels
|
||||
qui gèrent le chargement d'image par un système de
|
||||
\textsl{plugin}\index{plugin},
|
||||
|
11
essai.c
11
essai.c
@ -18,6 +18,8 @@ int verbosity;
|
||||
void fait_un_dessin(FloatImg *dessin)
|
||||
{
|
||||
|
||||
// fprintf(stderr, "je dessine dans %p\n", dessin);
|
||||
|
||||
fimg_draw_something(dessin);
|
||||
|
||||
}
|
||||
@ -26,6 +28,7 @@ void help(void)
|
||||
{
|
||||
puts("Options :");
|
||||
puts("\t-d WxH\timage size");
|
||||
puts("\t-v\tincrease verbosity");
|
||||
exit(0);
|
||||
}
|
||||
/* --------------------------------------------------------------------- */
|
||||
@ -57,7 +60,7 @@ fimg_drand48(&fimgB, 100.0);
|
||||
foo = fimg_dump_to_file(&fimgB, "B.fimg", 0);
|
||||
|
||||
fimg_timer_set(0);
|
||||
#define NBP 500
|
||||
#define NBP 5
|
||||
for (foo=0; foo<NBP; foo++) {
|
||||
if (verbosity) {
|
||||
printf("%5d / %5d\n", foo, NBP);
|
||||
@ -67,9 +70,9 @@ for (foo=0; foo<NBP; foo++) {
|
||||
// fimg_mul(&fimgA, &fimgB, &fimgA);
|
||||
}
|
||||
tb = fimg_timer_get(0);
|
||||
fprintf(stderr, "%s = %f seconds\n", __func__, tb);
|
||||
foo = fimg_save_as_pnm(&fimgA, "drand48.pnm", 0);
|
||||
foo = fimg_dump_to_file(&fimgA, "drand48.fimg", 0);
|
||||
fprintf(stderr, "%s = %.2f seconds, %.2f s/p\n", __func__, tb, tb/(double)NBP);
|
||||
foo = fimg_save_as_pnm(&fimgA, "out.pnm", 0);
|
||||
foo = fimg_dump_to_file(&fimgA, "out.fimg", 0);
|
||||
|
||||
fimg_destroy(&fimgA);
|
||||
fimg_destroy(&fimgB);
|
||||
|
@ -110,6 +110,9 @@ for (y=0; y<hd; y++) {
|
||||
return 0;
|
||||
}
|
||||
/* --------------------------------------------------------------------- */
|
||||
/*
|
||||
* this function can be optimized with direct pixel copy
|
||||
*/
|
||||
int fimg_extractor(FloatImg *in, FloatImg *out, FimgArea51 *rect)
|
||||
{
|
||||
int xs, ys, xd, yd;
|
||||
|
@ -19,7 +19,7 @@ do
|
||||
|
||||
# only take the good spot
|
||||
fimg=$(printf "%s/%05d.fimg" ${OUTD} ${idx})
|
||||
${EXTR} -o ${fimg} ${TMPG} 800,600,560,240 ${fimg}
|
||||
${EXTR} -o ${fimg} ${TMPG} 800,600,560,240
|
||||
|
||||
# display ${fimg} ; exit
|
||||
|
||||
|
@ -18,7 +18,9 @@ int extractor(char *srcname, char *dstname, FimgArea51 *rect)
|
||||
FloatImg src, dst;
|
||||
int foo;
|
||||
|
||||
#if DEBUG_LEVEL
|
||||
fprintf(stderr, ">>> %s ( %s %s %p )\n", __func__, srcname, dstname, rect);
|
||||
#endif
|
||||
|
||||
if (verbosity) {
|
||||
print_rectangle((char *)__func__, rect);
|
||||
|
Loading…
Reference in New Issue
Block a user