123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- --- a/configure.ac
- +++ b/configure.ac
- @@ -1957,7 +1957,7 @@ PKG_ENABLE_MODULES_VLC([VNC], [vnc], [li
-
- dnl RDP/Remote Desktop access module
- dnl
- -PKG_ENABLE_MODULES_VLC([FREERDP], [rdp], [freerdp >= 1.0.1], (RDP/Remote Desktop client support) )
- +PKG_ENABLE_MODULES_VLC([FREERDP], [rdp], [freerdp2 >= 1.0.1], (RDP/Remote Desktop client support) )
-
- dnl
- dnl Real RTSP plugin
- --- a/modules/access/rdp.c 2017-12-25 17:45:32.964429170 +0100
- +++ b/modules/access/rdp.c 2017-12-25 17:53:15.114093670 +0100
- @@ -45,18 +45,6 @@
- # include <freerdp/version.h>
- #endif
-
- -#if !defined(FREERDP_VERSION_MAJOR) || \
- - (defined(FREERDP_VERSION_MAJOR) && !(FREERDP_VERSION_MAJOR > 1 || (FREERDP_VERSION_MAJOR == 1 && FREERDP_VERSION_MINOR >= 1)))
- -# define SoftwareGdi sw_gdi
- -# define Fullscreen fullscreen
- -# define ServerHostname hostname
- -# define Username username
- -# define Password password
- -# define ServerPort port
- -# define EncryptionMethods encryption
- -# define ContextSize context_size
- -#endif
- -
- #include <errno.h>
- #ifdef HAVE_POLL
- # include <poll.h>
- @@ -140,6 +128,7 @@
- vlcrdp_context_t * p_vlccontext = (vlcrdp_context_t *) p_context;
- demux_sys_t *p_sys = p_vlccontext->p_demux->p_sys;
- rdpGdi *p_gdi = p_context->gdi;
- + unsigned bytesPerPixel;
-
- if ( p_sys->es )
- {
- @@ -149,19 +138,23 @@
-
- /* Now init and fill es format */
- vlc_fourcc_t i_chroma;
- - switch( p_gdi->bytesPerPixel )
- + switch( p_gdi->dstFormat )
- {
- default:
- - case 16:
- + msg_Dbg( p_vlccontext->p_demux, "unhandled dstFormat %x bpp", p_gdi->dstFormat);
- + case PIXEL_FORMAT_BGR16:
- i_chroma = VLC_CODEC_RGB16;
- + bytesPerPixel = 16;
- break;
- - case 24:
- + case PIXEL_FORMAT_BGR24:
- i_chroma = VLC_CODEC_RGB24;
- + bytesPerPixel = 24;
- break;
- - case 32:
- + case PIXEL_FORMAT_BGRA32:
- i_chroma = VLC_CODEC_RGB32;
- + bytesPerPixel = 32;
- break;
- }
- es_format_t fmt;
- es_format_Init( &fmt, VIDEO_ES, i_chroma );
-
- @@ -172,7 +165,7 @@
- fmt.video.i_height = p_gdi->height;
- fmt.video.i_frame_rate_base = 1000;
- fmt.video.i_frame_rate = 1000 * p_sys->f_fps;
- - p_sys->i_framebuffersize = p_gdi->width * p_gdi->height * p_gdi->bytesPerPixel;
- + p_sys->i_framebuffersize = p_gdi->width * p_gdi->height * bytesPerPixel;
-
- if ( p_sys->p_block )
- p_sys->p_block = block_Realloc( p_sys->p_block, 0, p_sys->i_framebuffersize );
- @@ -233,28 +226,19 @@
- vlcrdp_context_t * p_vlccontext = (vlcrdp_context_t *) p_instance->context;
-
- msg_Dbg( p_vlccontext->p_demux, "connected to desktop %dx%d (%d bpp)",
- -#if defined(FREERDP_VERSION_MAJOR) && (FREERDP_VERSION_MAJOR > 1 || (FREERDP_VERSION_MAJOR == 1 && FREERDP_VERSION_MINOR >= 1))
- p_instance->settings->DesktopWidth,
- p_instance->settings->DesktopHeight,
- p_instance->settings->ColorDepth
- -#else
- - p_instance->settings->width,
- - p_instance->settings->height,
- - p_instance->settings->color_depth
- -#endif
- );
-
- p_instance->update->DesktopResize = desktopResizeHandler;
- p_instance->update->BeginPaint = beginPaintHandler;
- p_instance->update->EndPaint = endPaintHandler;
-
- - gdi_init( p_instance,
- - CLRBUF_16BPP |
- -#if defined(FREERDP_VERSION_MAJOR) && defined(FREERDP_VERSION_MINOR) && \
- - !(FREERDP_VERSION_MAJOR > 1 || (FREERDP_VERSION_MAJOR == 1 && FREERDP_VERSION_MINOR >= 2))
- - CLRBUF_24BPP |
- -#endif
- - CLRBUF_32BPP, NULL );
- + if ( p_instance->settings->ColorDepth > 16 )
- + gdi_init( p_instance, PIXEL_FORMAT_XRGB32);
- + else
- + gdi_init( p_instance, PIXEL_FORMAT_RGB16);
-
- desktopResizeHandler( p_instance->context );
- return true;
- @@ -428,10 +412,6 @@
- if ( p_sys->f_fps <= 0 ) p_sys->f_fps = 1.0;
- p_sys->i_frame_interval = 1000000 / p_sys->f_fps;
-
- -#if FREERDP_VERSION_MAJOR == 1 && FREERDP_VERSION_MINOR < 2
- - freerdp_channels_global_init();
- -#endif
- -
- p_sys->p_instance = freerdp_new();
- if ( !p_sys->p_instance )
- {
- @@ -506,9 +486,6 @@
-
- freerdp_disconnect( p_sys->p_instance );
- freerdp_free( p_sys->p_instance );
- -#if FREERDP_VERSION_MAJOR == 1 && FREERDP_VERSION_MINOR < 2
- - freerdp_channels_global_uninit();
- -#endif
-
- if ( p_sys->p_block )
- block_Release( p_sys->p_block );
|