Codebase list frei0r / d0bd54f src / filter / transparency / transparency.c
d0bd54f

Tree @d0bd54f (Download .tar.gz)

transparency.c @d0bd54fraw · history · blame

#include "frei0r.h"
#include "frei0r/math.h"
#include <stdlib.h>
#include <assert.h>

typedef struct transparency_instance
{
  unsigned int width;
  unsigned int height;
  double transparency;
} transparency_instance_t;

int f0r_init()
{
  return 1;
}

void f0r_deinit()
{ /* no initialization required */ }

void f0r_get_plugin_info(f0r_plugin_info_t* transparencyInfo)
{
  transparencyInfo->name = "Transparency";
  transparencyInfo->author = "Richard Spindler";
  transparencyInfo->plugin_type = F0R_PLUGIN_TYPE_FILTER;
  transparencyInfo->color_model = F0R_COLOR_MODEL_RGBA8888;
  transparencyInfo->frei0r_version = FREI0R_MAJOR_VERSION;
  transparencyInfo->major_version = 0; 
  transparencyInfo->minor_version = 9; 
  transparencyInfo->num_params =  1; 
  transparencyInfo->explanation = "Tunes the alpha channel.";
}

void f0r_get_param_info(f0r_param_info_t* info, int param_index)
{
	switch(param_index)
	{
		case 0:
			info->name = "Transparency";
			info->type = F0R_PARAM_DOUBLE;
			info->explanation = "The transparency value";
			break;
	}
}

f0r_instance_t f0r_construct(unsigned int width, unsigned int height)
{
  transparency_instance_t* inst = (transparency_instance_t*)calloc(1, sizeof(*inst));
  inst->width = width; inst->height = height;
  inst->transparency = 0.0;
  return (f0r_instance_t)inst;
}

void f0r_destruct(f0r_instance_t instance)
{
  free(instance);
}

void f0r_set_param_value(f0r_instance_t instance, 
			 f0r_param_t param, int param_index)
{
	assert(instance);
	transparency_instance_t* inst = (transparency_instance_t*)instance;

	switch(param_index)
	{
		double val;
		case 0:
		/* transparency */
		val = *((double*)param);
		if (val != inst->transparency)
		{
			inst->transparency = val;
		}
		break;
	}

}

void f0r_get_param_value(f0r_instance_t instance,
			 f0r_param_t param, int param_index)
{
	assert(instance);
	transparency_instance_t* inst = (transparency_instance_t*)instance;
	switch(param_index)
	{
		case 0:
			*((double*)param) = inst->transparency;
			break;
	}
}

void f0r_update(f0r_instance_t instance, double time,
		const uint32_t* inframe, uint32_t* outframe)
{
  assert(instance);
  transparency_instance_t* inst = (transparency_instance_t*)instance;
  unsigned int w = inst->width;
  unsigned int h = inst->height;
  unsigned int x,y;
  
  uint32_t* dst = outframe;
  const uint32_t* src = inframe;
  uint8_t alpha  = (uint8_t)( inst->transparency * 255 );
  for(y=h;y>0;--y)
      for(x=w;x>0;--x,++src,++dst)
	{
	  uint8_t tmpalpha;
	  uint8_t* tmpc = (uint8_t*)src;
	  tmpalpha = MIN(alpha, tmpc[3]);
	  *dst = (tmpalpha << 24) | (tmpc[2] << 16) | (tmpc[1] << 8) | tmpc[0];
	}
}