diff options
| -rw-r--r-- | ChangeLog | 1 | ||||
| -rw-r--r-- | video.c | 48 | 
2 files changed, 26 insertions, 23 deletions
| @@ -2,6 +2,7 @@ User johns  Date:      Release Version 0.5.0 +    Faster VdpauBlackSurface version.      Fix bug: VideoSetPts wrong position for multi frame packets.  User: CafeDelMar @@ -7248,38 +7248,40 @@ static void VdpauMixVideo(VdpauDecoder * decoder)  ///	@param decoder	VDPAU hw decoder  ///  ///	@FIXME: render only video area, not fullscreen! +///	decoder->Output.. isn't correct setup for radio stations  ///  static void VdpauBlackSurface(VdpauDecoder * decoder)  {      VdpStatus status; -    void *image; -    void const *data[1]; -    uint32_t pitches[1]; -    VdpRect dst_rect; - -    Debug(3, "video/vdpau: black surface\n"); - -    // FIXME: clear video window area -    (void)decoder; - -    image = calloc(4, VideoWindowWidth * VideoWindowHeight); +    VdpRect source_rect; +    VdpRect output_rect; -    dst_rect.x0 = 0; -    dst_rect.y0 = 0; -    dst_rect.x1 = dst_rect.x0 + VideoWindowWidth; -    dst_rect.y1 = dst_rect.y0 + VideoWindowHeight; -    data[0] = image; -    pitches[0] = VideoWindowWidth * 4; +    source_rect.x0 = 0; +    source_rect.y0 = 0; +    source_rect.x1 = 0; +    source_rect.y1 = 0; + +    if ( 0 ) { +	// FIXME: wrong for radio channels +	output_rect.x0 = decoder->OutputX;	// video output (scale) +	output_rect.y0 = decoder->OutputY; +	output_rect.x1 = decoder->OutputX + decoder->OutputWidth; +	output_rect.y1 = decoder->OutputY + decoder->OutputHeight; +    } else { +	output_rect.x0 = 0; +	output_rect.y0 = 0; +	output_rect.x1 = VideoWindowWidth; +	output_rect.y1 = VideoWindowHeight; +    } -    status = -	VdpauOutputSurfacePutBitsNative(VdpauSurfacesRb[VdpauSurfaceIndex], -	data, pitches, &dst_rect); +    status = VdpauOutputSurfaceRenderOutputSurface( +	VdpauSurfacesRb[VdpauSurfaceIndex], &output_rect, +	VdpauOsdOutputSurface[!VdpauOsdSurfaceIndex], &source_rect, NULL, NULL, +	VDP_OUTPUT_SURFACE_RENDER_ROTATE_0);      if (status != VDP_STATUS_OK) { -	Error(_("video/vdpau: output surface put bits failed: %s\n"), +	Error(_("video/vdpau: can't render output surface: %s\n"),  	    VdpauGetErrorString(status));      } - -    free(image);  }  /// | 
