grabing floatimb picz from a webcam

This commit is contained in:
tth 2019-08-10 18:37:52 +02:00
parent 016497c870
commit 66cd54f3c6
10 changed files with 175 additions and 32 deletions

View File

@ -132,10 +132,13 @@ est en fait arbitraire.
\subsection{Structures, macros\dots} \subsection{Structures, macros\dots}
Les pixels flottants d'une image résidant en mémoire centrale
sont décrits par un ensemble
de données (certains appelent ça des \textsl{metadats}) regroupées
dans une jolie structure que nous allons examiner dès maintenant.
\begin{verbatim} \begin{verbatim}
/* /* in memory descriptor */
* in memory descriptor
*/
typedef struct { typedef struct {
int width; int width;
int height; int height;
@ -147,6 +150,26 @@ typedef struct {
} FloatImg; } FloatImg;
\end{verbatim}\index{FloatImg} \end{verbatim}\index{FloatImg}
Les deux premiers champs sont \textsl{obvious}.
Le troisième est le type d'image : pour le moment, il y en a trois
qui sont définis\footnote{et plus ou moins bien gérés\dots} :
gris, rgb et rgba\index{rgba}.
\begin{verbatim}
#define FIMG_TYPE_GRAY 1
#define FIMG_TYPE_RGB 3
#define FIMG_TYPE_RGBA 4
\end{verbatim}
Les deux champs suivants (fval et count) sont à la disposition du yuser
qui peut jouer avec à loisir.
Et pour finir dans la joie, nous avons les pointeurs vers les
différents \textsl{pixmaps} de l'image.
\subsection{lib/}\index{lib/} \subsection{lib/}\index{lib/}
@ -160,10 +183,20 @@ int fimg_destroy(FloatImg *fimg);
Les types d'images actuellement gérés sont les trois grands Les types d'images actuellement gérés sont les trois grands
classiques : gray, rgb et rgba. Il y a les constantes adéquates classiques : gray, rgb et rgba. Il y a les constantes adéquates
dans \texttt{floatimg.h}. dans \texttt{floatimg.h}. Les codes d'erreur sont disparates
et non documenté.
\vspace{1em}
Bon, vous avez une image latente, et
vous souhaité dessiner dessus (ou dedans ?) avec vos encres
flottantes ?
\subsection{funcs/}\index{funcs/} \subsection{funcs/}\index{funcs/}
Une bonne partie de ces fonctions est indéterministe. Ce qui
veut dire, en langage de tous les soirs, que ça risque de ne
pas être la même chose dans l'avenir.
% ------------------------------------------------------------------- % -------------------------------------------------------------------
\section{Les outils}\label{outils} \section{Les outils}\label{outils}
@ -173,7 +206,12 @@ in-fine sur des objets que l'on peut considérer comme « physiques »,
il est important de passer à une utilisation il est important de passer à une utilisation
normale\footnote{Il y a une vie en dehors de git.} et construire normale\footnote{Il y a une vie en dehors de git.} et construire
des trucs qui mettent en action le code primitif. des trucs qui mettent en action le code primitif.
% \vspace{1em} \vspace{1em}
Ces machins ont en commun deux options bien pratiques~:
\texttt{-h} pour avoir un résumé des options disponibles
et \texttt{-v} qui augmente la puissance de bavardage.
Dans un avenir incertain, il existera des pages de man\index{man}.
\subsection{mkfimg}\index{mkfimg}\label{mkfimg} \subsection{mkfimg}\index{mkfimg}\label{mkfimg}
@ -185,12 +223,26 @@ Création d'un fichier contenant une image de teinte constante.
Affichage de quelques valeurs calculées à partir d'un fichier Affichage de quelques valeurs calculées à partir d'un fichier
\texttt{.fimg}\index{.fimg}. \texttt{.fimg}\index{.fimg}.
\subsection{fimg2png et fimg2pnm}
\index{fimg2png}\label{fimg2png}
\index{fimg2pnm}\label{fimg2pnm}
Deux petits proggies pour exporter notre format\index{.fimg} secret
vers des choses plus directement utilisables.
% ------------------------------------------------------------------- % -------------------------------------------------------------------
\section{Video for Linux}\index{v4l2} \section{Video for Linux}\index{v4l2}
Donc, maintenant, nous savons un peu tripoter des images flottantes. Donc, maintenant, nous savons un peu tripoter ces images flottantes.
Et nous devons nous poser une question fondamentale\footnote{primitive ?} Et nous devons nous poser une question fondamentale\footnote{primitive ?}
sur la provenance de ces données prétendant être des images. sur la provenance de ces données prétendant être des images.
\vspace{1em}
En fait, notre désir secret est la découverte des choses cachées du
monde qui nous entoure. Nous voulons des images du \textbf{réel} et
pour cela, l'outil le plus commun, le plus répandu,
est la webcam\index{webcam}. L'universelle webcam.
% ------------------------------------------------------------------- % -------------------------------------------------------------------
\section{Et pour la suite ?} \section{Et pour la suite ?}
@ -199,7 +251,8 @@ En fait, je fait de la photo par la méthode du « cumul »
depuis plusieurs années. Une webcam\index{webcam}, depuis plusieurs années. Une webcam\index{webcam},
un Linux\index{Linux}, et ça \textsl{juste marche}. un Linux\index{Linux}, et ça \textsl{juste marche}.
Sauf que c'est quand même un peu galère à déplacer, il faut Sauf que c'est quand même un peu galère à déplacer, il faut
avoir un shell pour déclencher, c'est pas facile\dots avoir un shell pour déclencher, c'est pas facile à utiliser
en mode portnawak\dots
% ------------------------------------------------------------------- % -------------------------------------------------------------------

View File

@ -2,7 +2,7 @@
* floatimg.h * floatimg.h
*/ */
#define FIMG_VERSION 64 #define FIMG_VERSION 65
/* /*
* in memory descriptor * in memory descriptor

View File

@ -32,7 +32,8 @@ for (y=0; y<img->height; y++) {
return -1; return -1;
} }
/* ---------------------------------------------------------------- */ /* ---------------------------------------------------------------- */
#define W 4000
#define H 3000
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
int foo; int foo;
@ -43,15 +44,15 @@ verbosity = 1;
fimg_print_version(1); fimg_print_version(1);
foo = fimg_create(&dessin, 640, 480, 3); foo = fimg_create(&dessin, W, H, 3);
petit_dessin(&dessin); petit_dessin(&dessin);
fimg_save_as_pnm(&dessin, "dessin.pnm", 0); fimg_save_as_pnm(&dessin, "dessin.pnm", 0);
foo = fimg_create(&noise, 640, 480, 3); foo = fimg_create(&noise, W, H, 3);
fimg_drand48(&noise, 1.0); fimg_drand48(&noise, 1.0);
fimg_save_as_pnm(&noise, "noise.pnm", 0); fimg_save_as_pnm(&noise, "noise.pnm", 0);
foo = fimg_create(&result, 640, 480, 3); foo = fimg_create(&result, W, H, 3);
foo = fimg_add(&dessin, &noise, &result); foo = fimg_add(&dessin, &noise, &result);
fimg_save_as_pnm(&result, "r_add.pnm", 0); fimg_save_as_pnm(&result, "r_add.pnm", 0);

View File

@ -3,7 +3,7 @@
# use with caution # use with caution
# #
COPT = -Wall -fpic -g -DDEBUG_LEVEL=0 COPT = -Wall -fpic -g -DDEBUG_LEVEL=0 -lm
DEPS = ../floatimg.h ../libfloatimg.a Makefile DEPS = ../floatimg.h ../libfloatimg.a Makefile
# ---------- # ----------

View File

@ -11,11 +11,14 @@ t: t.c Makefile ${DEPS} funcs.o v4l2_pr_structs.o
funcs.o: funcs.c funcs.h Makefile funcs.o: funcs.c funcs.h Makefile
gcc ${COPT} -c $< gcc ${COPT} -c $<
rgb2fimg.o: rgb2fimg.c funcs.h Makefile
gcc ${COPT} -c $<
v4l2_pr_structs.o: v4l2_pr_structs.c v4l2_pr_structs.h Makefile v4l2_pr_structs.o: v4l2_pr_structs.c v4l2_pr_structs.h Makefile
gcc ${COPT} -c $< gcc ${COPT} -c $<
grabvidseq: grabvidseq.c Makefile grabvidseq: grabvidseq.c Makefile rgb2fimg.o
gcc -Wall -g $< ../libfloatimg.a -lv4l2 -o $@ gcc -Wall -g $< rgb2fimg.o ../libfloatimg.a -lv4l2 -o $@
video-infos: video-infos.c Makefile funcs.o v4l2_pr_structs.o video-infos: video-infos.c Makefile funcs.o v4l2_pr_structs.o
gcc -Wall -g $< funcs.o v4l2_pr_structs.o -o $@ gcc -Wall -g $< funcs.o v4l2_pr_structs.o -o $@

View File

@ -4,4 +4,13 @@
int open_device(char *dev_name); int open_device(char *dev_name);
int init_device(int notused); int init_device(int notused);
/* --------------------------------------------------------------------- */
int x_rgb2fimg(unsigned char *src, int w, int h, FloatImg *d);
int x_rgb2file(unsigned char *src, int w, int h, char *fname);
/* --------------------------------------------------------------------- */

View File

@ -27,9 +27,23 @@
#include <libv4l2.h> #include <libv4l2.h>
#include "../floatimg.h" #include "../floatimg.h"
#include "funcs.h"
/* --------------------------------------------------------------------- */
/* compilation control */
#define SAVE_AS_PNM 0
#define SAVE_AS_FIMG 1
/* --------------------------------------------------------------------- */
#define CLEAR(x) memset(&(x), 0, sizeof(x)) #define CLEAR(x) memset(&(x), 0, sizeof(x))
struct buffer { struct buffer {
void *start; void *start;
size_t length; size_t length;
@ -81,6 +95,7 @@ char out_name[256];
FILE *fout; FILE *fout;
struct buffer *buffers; struct buffer *buffers;
int foo, bar;
int period = 10; /* delai entre les captures */ int period = 10; /* delai entre les captures */
int nbre_capt = 1; /* nombre de captures */ int nbre_capt = 1; /* nombre de captures */
int opt; int opt;
@ -189,9 +204,12 @@ for (i = 0; i < nbre_capt; i++) {
buf.memory = V4L2_MEMORY_MMAP; buf.memory = V4L2_MEMORY_MMAP;
xioctl(fd, VIDIOC_DQBUF, &buf); xioctl(fd, VIDIOC_DQBUF, &buf);
#if SAVE_AS_PNM
/* at this time,we'v got a picture in-memory,
so we can blast in on storage */
sprintf(out_name, "%s/%05d.ppm", dest_dir, i); sprintf(out_name, "%s/%05d.ppm", dest_dir, i);
if (verbosity > 1) fprintf(stderr, "--> %s\n", out_name); if (verbosity > 1) fprintf(stderr, "--> %s\n", out_name);
fout = fopen(out_name, "w"); fout = fopen(out_name, "w");
if (!fout) { if (!fout) {
perror("Cannot open image"); perror("Cannot open image");
@ -202,6 +220,16 @@ for (i = 0; i < nbre_capt; i++) {
fwrite(buffers[buf.index].start, buf.bytesused, 1, fout); fwrite(buffers[buf.index].start, buf.bytesused, 1, fout);
fclose(fout); fclose(fout);
#endif
#if SAVE_AS_FIMG
sprintf(out_name, "%s/%05d.fimg", dest_dir, i);
if (verbosity > 1) fprintf(stderr, "--> %s\n", out_name);
foo = x_rgb2file(buffers[buf.index].start,
fmt.fmt.pix.width, fmt.fmt.pix.height,
out_name);
#endif
if (nbre_capt > 1 && period) { if (nbre_capt > 1 && period) {
sleep(period); sleep(period);
} }

58
v4l2/rgb2fimg.c Normal file
View File

@ -0,0 +1,58 @@
#include <stdio.h>
#include <stdlib.h>
#include "../floatimg.h"
#include "funcs.h"
/* --------------------------------------------------------------------- */
int x_rgb2fimg(unsigned char *src, int w, int h, FloatImg *d)
{
int iter, size;
float *rp, *gp, *bp;
size = w * h;
rp = d->R, gp = d->G, bp = d->G;
for (iter=0; iter<size; iter++) {
*rp++ = (float)*src++;
*gp++ = (float)*src++;
*bp++ = (float)*src++;
}
return 0;
}
/* --------------------------------------------------------------------- */
int x_rgb2file(unsigned char *src, int w, int h, char *fname)
{
FloatImg buff;
int foo;
#if DEBUG_LEVEL
fprintf(stderr, ">>> %s ( %p %d %d '%s' )\n", __func__,
src, w, h, fname);
#endif
foo = fimg_create(&buff, w, h, FIMG_TYPE_RGB);
if (foo) {
fprintf(stderr, "Crash on create in %s %s\n", __FILE__, __func__);
exit(1);
}
foo = x_rgb2fimg(src, w, h, &buff);
if (foo) {
fprintf(stderr, "Crash on bit massage in %s %s\n", __FILE__, __func__);
exit(1);
}
foo = fimg_dump_to_file(&buff, fname, 0);
if (foo) {
fprintf(stderr, "Crash on dump in %s %s\n", __FILE__, __func__);
exit(1);
}
fimg_destroy(&buff);
return -1;
}
/* --------------------------------------------------------------------- */

View File

@ -11,8 +11,8 @@
#include <inttypes.h> #include <inttypes.h>
#include <linux/videodev2.h> #include <linux/videodev2.h>
#include "funcs.h"
#include "../floatimg.h" #include "../floatimg.h"
#include "funcs.h"
#include "v4l2_pr_structs.h" #include "v4l2_pr_structs.h"

View File

@ -175,7 +175,7 @@ char ligne[100];
struct v4l2_capability cap; struct v4l2_capability cap;
struct v4l2_format fmt; struct v4l2_format fmt;
struct v4l2_input input; // struct v4l2_input input;
// int index; // int index;
// struct v4l2_requestbuffers reqbuf; // struct v4l2_requestbuffers reqbuf;
@ -202,26 +202,17 @@ pr_v4l2_capability(devname, &cap);
foo = enum_inputs(vfd, "on peut voir quoi ?", 0); foo = enum_inputs(vfd, "on peut voir quoi ?", 0);
/***
memset(&input, 0, sizeof(input));
input.index = 1;
if (-1 == ioctl(vfd, VIDIOC_ENUMINPUT, &input)) {
perror("VIDIOC_ENUMINPUT");
exit(EXIT_FAILURE);
}
sprintf(ligne, "input %d", input.index);
pr_v4l2_input(ligne, &input);
***/
memset(&fmt, 0, sizeof(fmt)); memset(&fmt, 0, sizeof(fmt));
fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
foo = ioctl(vfd, VIDIOC_G_FMT, &fmt); foo = ioctl(vfd, VIDIOC_G_FMT, &fmt);
fprintf(stderr, "ioctl -> %d\n", foo);
if (0 != foo) { if (0 != foo) {
perror("ioctl G_FMT"); perror("ioctl G_FMT");
exit(1); // exit(1);
}
else {
pr_v4l2_format("Experimental", &fmt);
} }
pr_v4l2_format("Experimental", &fmt);
foo = enum_image_formats(vfd, "Experimental", 0); foo = enum_image_formats(vfd, "Experimental", 0);