Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "media/video/gpu_memory_buffer_video_frame_pool.h" | 5 #include "media/video/gpu_memory_buffer_video_frame_pool.h" |
| 6 | 6 |
| 7 #include <GLES2/gl2.h> | 7 #include <GLES2/gl2.h> |
| 8 #include <GLES2/gl2ext.h> | 8 #include <GLES2/gl2ext.h> |
| 9 | 9 |
| 10 #include <algorithm> | 10 #include <algorithm> |
| (...skipping 562 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 573 // Create the VideoFrame backed by native textures. | 573 // Create the VideoFrame backed by native textures. |
| 574 gfx::Size visible_size = video_frame->visible_rect().size(); | 574 gfx::Size visible_size = video_frame->visible_rect().size(); |
| 575 switch (output_format_) { | 575 switch (output_format_) { |
| 576 case PIXEL_FORMAT_I420: | 576 case PIXEL_FORMAT_I420: |
| 577 frame = VideoFrame::WrapYUV420NativeTextures( | 577 frame = VideoFrame::WrapYUV420NativeTextures( |
| 578 mailbox_holders[VideoFrame::kYPlane], | 578 mailbox_holders[VideoFrame::kYPlane], |
| 579 mailbox_holders[VideoFrame::kUPlane], | 579 mailbox_holders[VideoFrame::kUPlane], |
| 580 mailbox_holders[VideoFrame::kVPlane], release_mailbox_callback, | 580 mailbox_holders[VideoFrame::kVPlane], release_mailbox_callback, |
| 581 coded_size, gfx::Rect(visible_size), video_frame->natural_size(), | 581 coded_size, gfx::Rect(visible_size), video_frame->natural_size(), |
| 582 video_frame->timestamp()); | 582 video_frame->timestamp()); |
| 583 if (video_frame->metadata()->IsTrue(VideoFrameMetadata::ALLOW_OVERLAY)) | 583 if (frame && |
| 584 video_frame->metadata()->IsTrue(VideoFrameMetadata::ALLOW_OVERLAY)) | |
|
Pawel Osciak
2015/11/26 01:19:03
I'm wondering why this check, I don't think WrapYU
emircan
2015/12/04 04:20:09
It is checking the |video_frame| metadata rather t
| |
| 584 frame->metadata()->SetBoolean(VideoFrameMetadata::ALLOW_OVERLAY, true); | 585 frame->metadata()->SetBoolean(VideoFrameMetadata::ALLOW_OVERLAY, true); |
| 585 break; | 586 break; |
| 586 case PIXEL_FORMAT_NV12: | 587 case PIXEL_FORMAT_NV12: |
| 587 case PIXEL_FORMAT_UYVY: | 588 case PIXEL_FORMAT_UYVY: |
| 588 frame = VideoFrame::WrapNativeTexture( | 589 frame = VideoFrame::WrapNativeTexture( |
| 589 output_format_, mailbox_holders[VideoFrame::kYPlane], | 590 output_format_, mailbox_holders[VideoFrame::kYPlane], |
| 590 release_mailbox_callback, coded_size, gfx::Rect(visible_size), | 591 release_mailbox_callback, coded_size, gfx::Rect(visible_size), |
| 591 video_frame->natural_size(), video_frame->timestamp()); | 592 video_frame->natural_size(), video_frame->timestamp()); |
| 592 frame->metadata()->SetBoolean(VideoFrameMetadata::ALLOW_OVERLAY, true); | 593 if (frame) |
| 594 frame->metadata()->SetBoolean(VideoFrameMetadata::ALLOW_OVERLAY, true); | |
| 593 break; | 595 break; |
| 594 default: | 596 default: |
| 595 NOTREACHED(); | 597 NOTREACHED(); |
| 596 } | 598 } |
| 597 | 599 |
| 600 if (!frame) { | |
| 601 release_mailbox_callback.Run(gpu::SyncToken()); | |
| 602 frame_ready_cb.Run(video_frame); | |
| 603 return; | |
| 604 } | |
| 605 | |
| 598 base::TimeTicks render_time; | 606 base::TimeTicks render_time; |
| 599 if (video_frame->metadata()->GetTimeTicks(VideoFrameMetadata::REFERENCE_TIME, | 607 if (video_frame->metadata()->GetTimeTicks(VideoFrameMetadata::REFERENCE_TIME, |
| 600 &render_time)) { | 608 &render_time)) { |
| 601 frame->metadata()->SetTimeTicks(VideoFrameMetadata::REFERENCE_TIME, | 609 frame->metadata()->SetTimeTicks(VideoFrameMetadata::REFERENCE_TIME, |
| 602 render_time); | 610 render_time); |
| 603 } | 611 } |
| 604 | 612 |
| 605 frame_ready_cb.Run(frame); | 613 frame_ready_cb.Run(frame); |
| 606 } | 614 } |
| 607 | 615 |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 738 } | 746 } |
| 739 | 747 |
| 740 void GpuMemoryBufferVideoFramePool::MaybeCreateHardwareFrame( | 748 void GpuMemoryBufferVideoFramePool::MaybeCreateHardwareFrame( |
| 741 const scoped_refptr<VideoFrame>& video_frame, | 749 const scoped_refptr<VideoFrame>& video_frame, |
| 742 const FrameReadyCB& frame_ready_cb) { | 750 const FrameReadyCB& frame_ready_cb) { |
| 743 DCHECK(video_frame); | 751 DCHECK(video_frame); |
| 744 pool_impl_->CreateHardwareFrame(video_frame, frame_ready_cb); | 752 pool_impl_->CreateHardwareFrame(video_frame, frame_ready_cb); |
| 745 } | 753 } |
| 746 | 754 |
| 747 } // namespace media | 755 } // namespace media |
| OLD | NEW |