/* * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #include "webrtc/test/frame_utils.h" #include "webrtc/video_frame.h" namespace webrtc { namespace test { bool EqualPlane(const uint8_t* data1, const uint8_t* data2, int stride, int width, int height) { for (int y = 0; y < height; ++y) { if (memcmp(data1, data2, width) != 0) return false; data1 += stride; data2 += stride; } return true; } bool FramesEqual(const webrtc::VideoFrame& f1, const webrtc::VideoFrame& f2) { if (f1.width() != f2.width() || f1.height() != f2.height() || f1.stride(webrtc::kYPlane) != f2.stride(webrtc::kYPlane) || f1.stride(webrtc::kUPlane) != f2.stride(webrtc::kUPlane) || f1.stride(webrtc::kVPlane) != f2.stride(webrtc::kVPlane) || f1.timestamp() != f2.timestamp() || f1.ntp_time_ms() != f2.ntp_time_ms() || f1.render_time_ms() != f2.render_time_ms()) { return false; } const int half_width = (f1.width() + 1) / 2; const int half_height = (f1.height() + 1) / 2; return EqualPlane(f1.buffer(webrtc::kYPlane), f2.buffer(webrtc::kYPlane), f1.stride(webrtc::kYPlane), f1.width(), f1.height()) && EqualPlane(f1.buffer(webrtc::kUPlane), f2.buffer(webrtc::kUPlane), f1.stride(webrtc::kUPlane), half_width, half_height) && EqualPlane(f1.buffer(webrtc::kVPlane), f2.buffer(webrtc::kVPlane), f1.stride(webrtc::kVPlane), half_width, half_height); } bool FrameBufsEqual(const rtc::scoped_refptr& f1, const rtc::scoped_refptr& f2) { if (f1->width() != f2->width() || f1->height() != f2->height() || f1->stride(webrtc::kYPlane) != f2->stride(webrtc::kYPlane) || f1->stride(webrtc::kUPlane) != f2->stride(webrtc::kUPlane) || f1->stride(webrtc::kVPlane) != f2->stride(webrtc::kVPlane)) { return false; } const int half_width = (f1->width() + 1) / 2; const int half_height = (f1->height() + 1) / 2; return EqualPlane(f1->data(webrtc::kYPlane), f2->data(webrtc::kYPlane), f1->stride(webrtc::kYPlane), f1->width(), f1->height()) && EqualPlane(f1->data(webrtc::kUPlane), f2->data(webrtc::kUPlane), f1->stride(webrtc::kUPlane), half_width, half_height) && EqualPlane(f1->data(webrtc::kVPlane), f2->data(webrtc::kVPlane), f1->stride(webrtc::kVPlane), half_width, half_height); } } // namespace test } // namespace webrtc