⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 magnify.c

📁 uclinux 下的vlc播放器源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
/***************************************************************************** * magnify.c : Magnify/Zoom interactive effect ***************************************************************************** * Copyright (C) 2005 the VideoLAN team * $Id: magnify.c 17012 2006-10-09 22:11:32Z xtophe $ * * Authors: Antoine Cellerier <dionoea -at- videolan -dot- org> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************//***************************************************************************** * Preamble *****************************************************************************/#include <stdlib.h>                                      /* malloc(), free() */#include <string.h>#include <vlc/vlc.h>#include <vlc/vout.h>#include <math.h>#include "filter_common.h"#include "vlc_image.h"#include "vlc_input.h"#include "vlc_playlist.h"/***************************************************************************** * Local prototypes *****************************************************************************/static int  Create    ( vlc_object_t * );static void Destroy   ( vlc_object_t * );static int  Init      ( vout_thread_t * );static void End       ( vout_thread_t * );static void Render    ( vout_thread_t *, picture_t * );static int  SendEvents   ( vlc_object_t *, char const *,                           vlc_value_t, vlc_value_t, void * );static int  MouseEvent   ( vlc_object_t *, char const *,                           vlc_value_t, vlc_value_t, void * );/***************************************************************************** * Module descriptor *****************************************************************************/vlc_module_begin();    set_description( _("Magnify/Zoom interactive video filter") );    set_shortname( _( "Magnify" ));    set_capability( "video filter", 0 );    set_category( CAT_VIDEO );    set_subcategory( SUBCAT_VIDEO_VFILTER );    set_callbacks( Create, Destroy );vlc_module_end();/***************************************************************************** * vout_sys_t: Magnify video output method descriptor *****************************************************************************/struct vout_sys_t{    vout_thread_t *p_vout;    image_handler_t *p_image;    int i_zoom; /* zoom level in percent */    int i_x, i_y; /* top left corner coordinates in original image */    vlc_bool_t b_visible; /* is "interface" visible ? */};/***************************************************************************** * Control: control facility for the vout (forwards to child vout) *****************************************************************************/static int Control( vout_thread_t *p_vout, int i_query, va_list args ){    return vout_vaControl( p_vout->p_sys->p_vout, i_query, args );}/***************************************************************************** * Create: allocates Magnify video thread output method *****************************************************************************/static int Create( vlc_object_t *p_this ){    vout_thread_t *p_vout = (vout_thread_t *)p_this;    /* Allocate structure */    p_vout->p_sys = malloc( sizeof( vout_sys_t ) );    if( p_vout->p_sys == NULL )    {        msg_Err( p_vout, "out of memory" );        return VLC_ENOMEM;    }    p_vout->p_sys->p_image = image_HandlerCreate( p_vout );    p_vout->pf_init = Init;    p_vout->pf_end = End;    p_vout->pf_manage = NULL;    p_vout->pf_render = Render;    p_vout->pf_display = NULL;    p_vout->pf_control = Control;    return VLC_SUCCESS;}/***************************************************************************** * Init: initialize Magnify video thread output method *****************************************************************************/static int Init( vout_thread_t *p_vout ){    int i_index;    picture_t *p_pic;    video_format_t fmt = {0};    I_OUTPUTPICTURES = 0;    /* Initialize the output structure */    p_vout->output.i_chroma = p_vout->render.i_chroma;    p_vout->output.i_width  = p_vout->render.i_width;    p_vout->output.i_height = p_vout->render.i_height;    p_vout->output.i_aspect = p_vout->render.i_aspect;    p_vout->fmt_out = p_vout->fmt_in;    fmt = p_vout->fmt_out;    /* Try to open the real video output */    msg_Dbg( p_vout, "spawning the real video output" );    p_vout->p_sys->p_vout = vout_Create( p_vout, &fmt );    /* Everything failed */    if( p_vout->p_sys->p_vout == NULL )    {        msg_Err( p_vout, "cannot open vout, aborting" );        return VLC_EGENERIC;    }#define VIS_ZOOM 4    p_vout->p_sys->i_x = 0;    p_vout->p_sys->i_y = 0;#define ZOOM_FACTOR 100    p_vout->p_sys->i_zoom = 200;    var_AddCallback( p_vout->p_sys->p_vout, "mouse-x", MouseEvent, p_vout );    var_AddCallback( p_vout->p_sys->p_vout, "mouse-y", MouseEvent, p_vout );    var_AddCallback( p_vout->p_sys->p_vout, "mouse-clicked",                     MouseEvent, p_vout);    ALLOCATE_DIRECTBUFFERS( VOUT_MAX_PICTURES );    ADD_CALLBACKS( p_vout->p_sys->p_vout, SendEvents );    ADD_PARENT_CALLBACKS( SendEventsToChild );    return VLC_SUCCESS;}/***************************************************************************** * End: terminate Magnify video thread output method *****************************************************************************/static void End( vout_thread_t *p_vout ){    int i_index;    /* Free the fake output buffers we allocated */    for( i_index = I_OUTPUTPICTURES ; i_index ; )    {        i_index--;        free( PP_OUTPUTPICTURE[ i_index ]->p_data_orig );    }    var_DelCallback( p_vout->p_sys->p_vout, "mouse-x", MouseEvent, p_vout);    var_DelCallback( p_vout->p_sys->p_vout, "mouse-y", MouseEvent, p_vout);    var_DelCallback( p_vout->p_sys->p_vout, "mouse-clicked", MouseEvent, p_vout);}/***************************************************************************** * Destroy: destroy Magnify video thread output method *****************************************************************************/static void Destroy( vlc_object_t *p_this ){    vout_thread_t *p_vout = (vout_thread_t *)p_this;    if( p_vout->p_sys->p_vout )    {        DEL_CALLBACKS( p_vout->p_sys->p_vout, SendEvents );        vlc_object_detach( p_vout->p_sys->p_vout );        vout_Destroy( p_vout->p_sys->p_vout );    }    image_HandlerDelete( p_vout->p_sys->p_image );    DEL_PARENT_CALLBACKS( SendEventsToChild );    free( p_vout->p_sys );}/***************************************************************************** * Render: displays previously rendered output *****************************************************************************/static void Render( vout_thread_t *p_vout, picture_t *p_pic ){    picture_t *p_outpic;    int o_x = p_vout->p_sys->i_x;    int o_y = p_vout->p_sys->i_y;    int o_zoom = p_vout->p_sys->i_zoom;    int x,y,o_yp,o_xp;    int v_w, v_h;    video_format_t fmt_out = {0};    picture_t *p_converted;    plane_t *p_oyp=NULL;    /* This is a new frame. Get a structure from the video_output. */    while( ( p_outpic = vout_CreatePicture( p_vout->p_sys->p_vout, 0, 0, 0 ) )              == NULL )    {        if( p_vout->b_die || p_vout->b_error )        {            return;        }        msleep( VOUT_OUTMEM_SLEEP );    }    vout_DatePicture( p_vout->p_sys->p_vout, p_outpic, p_pic->date );    p_oyp = &(p_outpic->p[Y_PLANE]);    /* background magnified image */    if( o_zoom != ZOOM_FACTOR )    {#define magnify( plane ) \    o_yp = o_y*p_outpic->p[plane].i_lines/p_outpic->p[Y_PLANE].i_lines; \    o_xp = o_x*p_outpic->p[plane].i_pitch/p_outpic->p[Y_PLANE].i_pitch; \    for( y=0; y<p_outpic->p[plane].i_visible_lines; y++ ) \    { \        for( x=0; x<p_outpic->p[plane].i_visible_pitch; x++ ) \        { \            p_outpic->p[plane].p_pixels[y*p_outpic->p[plane].i_pitch+x] = \                p_pic->p[plane].p_pixels[ \                    ( o_yp + y*ZOOM_FACTOR/o_zoom )*p_outpic->p[plane].i_pitch \                    + o_xp + x*ZOOM_FACTOR/o_zoom \                ]; \        } \    }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -