Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(120)

Side by Side Diff: webrtc/examples/peerconnection/client/linux/main_wnd.cc

Issue 2287233002: Delete cricket::VideoFrame::ConvertToRgbBuffer. (Closed)
Patch Set: Convert non-linux renderers. Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2012 The WebRTC Project Authors. All rights reserved. 2 * Copyright 2012 The WebRTC Project Authors. All rights reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #include "webrtc/examples/peerconnection/client/linux/main_wnd.h" 11 #include "webrtc/examples/peerconnection/client/linux/main_wnd.h"
12 12
13 #include <gdk/gdkkeysyms.h> 13 #include <gdk/gdkkeysyms.h>
14 #include <gtk/gtk.h> 14 #include <gtk/gtk.h>
15 #include <stddef.h> 15 #include <stddef.h>
16 16
17 #include "libyuv/convert_from.h"
17 #include "webrtc/examples/peerconnection/client/defaults.h" 18 #include "webrtc/examples/peerconnection/client/defaults.h"
18 #include "webrtc/base/common.h" 19 #include "webrtc/base/common.h"
19 #include "webrtc/base/logging.h" 20 #include "webrtc/base/logging.h"
20 #include "webrtc/base/stringutils.h" 21 #include "webrtc/base/stringutils.h"
21 22
22 using rtc::sprintfn; 23 using rtc::sprintfn;
23 24
24 namespace { 25 namespace {
25 26
26 // 27 //
(...skipping 455 matching lines...) Expand 10 before | Expand all | Expand 10 after
482 483
483 void GtkMainWnd::VideoRenderer::OnFrame( 484 void GtkMainWnd::VideoRenderer::OnFrame(
484 const cricket::VideoFrame& video_frame) { 485 const cricket::VideoFrame& video_frame) {
485 gdk_threads_enter(); 486 gdk_threads_enter();
486 487
487 const cricket::VideoFrame* frame = video_frame.GetCopyWithRotationApplied(); 488 const cricket::VideoFrame* frame = video_frame.GetCopyWithRotationApplied();
488 489
489 SetSize(frame->width(), frame->height()); 490 SetSize(frame->width(), frame->height());
490 491
491 int size = width_ * height_ * 4; 492 int size = width_ * height_ * 4;
493
492 // TODO(henrike): Convert directly to RGBA 494 // TODO(henrike): Convert directly to RGBA
perkj_webrtc 2016/08/30 07:13:39 Did you check if there is a RGBA convert in libyuv
nisse-webrtc 2016/08/30 07:46:07 There is, it seems. One could also call I420ToRGBA
493 frame->ConvertToRgbBuffer(cricket::FOURCC_ARGB, 495 rtc::scoped_refptr<webrtc::VideoFrameBuffer> buffer(
494 image_.get(), 496 frame->video_frame_buffer());
495 size, 497 libyuv::ConvertFromI420(buffer->DataY(), buffer->StrideY(),
496 width_ * 4); 498 buffer->DataU(), buffer->StrideU(),
499 buffer->DataV(), buffer->StrideV(),
500 image_.get(), width_ * 4,
501 buffer->width(), buffer->height(),
502 cricket::FOURCC_ARGB);
perkj_webrtc 2016/08/30 07:13:39 use libyuv type not cricket::FOURCC_...
503
497 // Convert the B,G,R,A frame to R,G,B,A, which is accepted by GTK. 504 // Convert the B,G,R,A frame to R,G,B,A, which is accepted by GTK.
498 // The 'A' is just padding for GTK, so we can use it as temp. 505 // The 'A' is just padding for GTK, so we can use it as temp.
499 uint8_t* pix = image_.get(); 506 uint8_t* pix = image_.get();
500 uint8_t* end = image_.get() + size; 507 uint8_t* end = image_.get() + size;
501 while (pix < end) { 508 while (pix < end) {
502 pix[3] = pix[0]; // Save B to A. 509 pix[3] = pix[0]; // Save B to A.
503 pix[0] = pix[2]; // Set Red. 510 pix[0] = pix[2]; // Set Red.
504 pix[2] = pix[3]; // Set Blue. 511 pix[2] = pix[3]; // Set Blue.
505 pix[3] = 0xFF; // Fixed Alpha. 512 pix[3] = 0xFF; // Fixed Alpha.
506 pix += 4; 513 pix += 4;
507 } 514 }
508 515
509 gdk_threads_leave(); 516 gdk_threads_leave();
510 517
511 g_idle_add(Redraw, main_wnd_); 518 g_idle_add(Redraw, main_wnd_);
512 } 519 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698