changeset 7856:ac161720f4f0

sample client for -vop bmovl -- loads and alphablend any PNG file
author arpi
date Wed, 23 Oct 2002 00:28:27 +0000
parents fe88f7403d64
children 3c690d2ad1ac
files TOOLS/bmovl-test/Makefile TOOLS/bmovl-test/bmovl-test.c
diffstat 2 files changed, 118 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TOOLS/bmovl-test/Makefile	Wed Oct 23 00:28:27 2002 +0000
@@ -0,0 +1,2 @@
+bmovl-test: bmovl-test.c
+	gcc -O3 -I/usr/local/include/SDL -L/usr/local/lib -lSDL_image -o bmovl-test bmovl-test.c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/TOOLS/bmovl-test/bmovl-test.c	Wed Oct 23 00:28:27 2002 +0000
@@ -0,0 +1,116 @@
+/* Small program to test the features of vf_bmovl */
+
+#include <unistd.h>
+#include <fcntl.h>
+#include <SDL.h>
+#include <SDL_image.h>
+
+#define DEBUG 0
+
+static void
+blit(int fifo, unsigned char *bitmap, int width, int height,
+     int xpos, int ypos, int alpha, int clear)
+{
+	char str[100];
+	int  nbytes;
+	
+	sprintf(str, "RGBA32 %d %d %d %d %d %d\n",
+	        width, height, xpos, ypos, alpha, clear);
+	
+	if(DEBUG) printf("Sending %s", str);
+
+	write(fifo, str, strlen(str));
+	nbytes = write(fifo, bitmap, width*height*4);
+
+	if(DEBUG) printf("Sent %d bytes of bitmap data...\n", nbytes);
+}
+
+static void
+set_alpha(int fifo, int width, int height, int xpos, int ypos, int alpha) {
+	char str[100];
+
+	sprintf(str, "ALPHA %d %d %d %d %d\n",
+	        width, height, xpos, ypos, alpha);
+	
+	if(DEBUG) printf("Sending %s", str);
+
+	write(fifo, str, strlen(str));
+}
+
+static void
+paint(unsigned char* bitmap, int size, int red, int green, int blue, int alpha) {
+
+	int i;
+
+	for(i=0; i < size; i+=4) {
+		bitmap[i+0] = red;
+		bitmap[i+1] = green;
+		bitmap[i+2] = blue;
+		bitmap[i+3] = alpha;
+	}
+}
+
+int main(int argc, char **argv) {
+
+	int fifo=-1;
+	int width=0, height=0, xpos=0, ypos=0, alpha=0, clear=0;
+	unsigned char *bitmap;
+	SDL_Surface *image;
+	int i;
+
+	if(argc<3) {
+		printf("Usage: %s <bmovl fifo> <image file> <width> <height>\n", argv[0]);
+		printf("width and height are w/h of MPlayer's screen!\n");
+		exit(10);
+	}
+
+	width = atoi(argv[3]);
+	height = atoi(argv[4]);
+
+	fifo = open( argv[1], O_RDWR );
+	if(!fifo) {
+		fprintf(stderr, "Error opening FIFO %s!\n", argv[1]);
+		exit(10);
+	}
+
+	image = IMG_Load(argv[2]);
+	if(!image) {
+		fprintf(stderr, "Couldn't load image %s!\n", argv[2]);
+		exit(10);
+	}
+
+	printf("Loaded image %s: width=%d, height=%d\n", argv[2], image->w, image->h);
+
+	// Display and move image
+	for(i=0; (i < (width - image->w)) && (i < (height - image->h)); i += 5)
+		blit(fifo, image->pixels, image->w, image->h, i, i, 0, 1);
+
+	// Create a 75x75 bitmap
+	bitmap = (unsigned char*)malloc(75*75*4);
+
+	// Paint bitmap red, 50% transparent and blit at position 50,50
+	paint(bitmap, (75*75*4), 255, 0, 0, 128);
+	blit(fifo, bitmap, 75, 75, 50, 50, 0, 0);
+
+	// Paint bitmap green, 50% transparent and blit at position -50,50
+	paint(bitmap, (75*75*4), 0, 255, 0, 128);
+	blit(fifo, bitmap, 75, 75, width-50-75, 50, 0, 0);
+
+	// Paint bitmap green, 50% transparent and blit at position -50,50
+	paint(bitmap, (75*75*4), 0, 0, 255, 128);
+	blit(fifo, bitmap, 75, 75, 50, height-50-75, 0, 0);
+
+	// Blit another image in the middle, completly transparent
+	blit(fifo, image->pixels, image->w, image->h,
+	           (width/2)-(image->w/2), (height/2)-(image->h/2), -255, 0);
+
+	// Fade in image
+	for(i=-255; i <= 0; i++)
+		set_alpha(fifo, image->w, image->h,
+		          (width/2)-(image->w/2), (height/2)-(image->h/2), i);
+	
+
+	// Clean up
+	free(bitmap);
+	SDL_FreeSurface(image);
+}