blob: f92d7afa80f29a0bc22ae0d12ade21768ddfa3b4 [file] [log] [blame]
// Copyright 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "cc/test/fake_output_surface.h"
#include "base/bind.h"
#include "base/threading/thread_task_runner_handle.h"
#include "components/viz/common/resources/returned_resource.h"
#include "components/viz/service/display/output_surface_client.h"
#include "components/viz/test/begin_frame_args_test.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "ui/gfx/presentation_feedback.h"
#include "ui/gl/gl_utils.h"
namespace cc {
FakeOutputSurface::FakeOutputSurface(
scoped_refptr<viz::ContextProvider> context_provider)
: OutputSurface(std::move(context_provider)), weak_ptr_factory_(this) {
DCHECK(OutputSurface::context_provider());
}
FakeOutputSurface::FakeOutputSurface(
std::unique_ptr<viz::SoftwareOutputDevice> software_device)
: OutputSurface(std::move(software_device)), weak_ptr_factory_(this) {
DCHECK(OutputSurface::software_device());
}
FakeOutputSurface::~FakeOutputSurface() = default;
void FakeOutputSurface::Reshape(const gfx::Size& size,
float device_scale_factor,
const gfx::ColorSpace& color_space,
bool has_alpha,
bool use_stencil) {
if (context_provider()) {
context_provider()->ContextGL()->ResizeCHROMIUM(
size.width(), size.height(), device_scale_factor,
gl::GetGLColorSpace(color_space), has_alpha);
} else {
software_device()->Resize(size, device_scale_factor);
}
last_reshape_color_space_ = color_space;
}
void FakeOutputSurface::SwapBuffers(viz::OutputSurfaceFrame frame) {
last_sent_frame_ =
std::make_unique<viz::OutputSurfaceFrame>(std::move(frame));
++num_sent_frames_;
base::ThreadTaskRunnerHandle::Get()->PostTask(
FROM_HERE,
base::BindOnce(&FakeOutputSurface::SwapBuffersAck,
weak_ptr_factory_.GetWeakPtr(), num_sent_frames_));
}
void FakeOutputSurface::SwapBuffersAck(uint64_t swap_id) {
client_->DidReceiveSwapBuffersAck(swap_id);
client_->DidReceivePresentationFeedback(swap_id, gfx::PresentationFeedback());
}
void FakeOutputSurface::BindFramebuffer() {
context_provider_->ContextGL()->BindFramebuffer(GL_FRAMEBUFFER, framebuffer_);
}
void FakeOutputSurface::SetDrawRectangle(const gfx::Rect& rect) {
last_set_draw_rectangle_ = rect;
}
uint32_t FakeOutputSurface::GetFramebufferCopyTextureFormat() {
if (framebuffer_)
return framebuffer_format_;
else
return GL_RGB;
}
void FakeOutputSurface::BindToClient(viz::OutputSurfaceClient* client) {
DCHECK(client);
DCHECK(!client_);
client_ = client;
}
bool FakeOutputSurface::HasExternalStencilTest() const {
return has_external_stencil_test_;
}
bool FakeOutputSurface::SurfaceIsSuspendForRecycle() const {
return suspended_for_recycle_;
}
viz::OverlayCandidateValidator*
FakeOutputSurface::GetOverlayCandidateValidator() const {
return overlay_candidate_validator_;
}
gfx::BufferFormat FakeOutputSurface::GetOverlayBufferFormat() const {
return gfx::BufferFormat::RGBX_8888;
}
bool FakeOutputSurface::IsDisplayedAsOverlayPlane() const {
return false;
}
unsigned FakeOutputSurface::GetOverlayTextureId() const {
return 0;
}
#if BUILDFLAG(ENABLE_VULKAN)
gpu::VulkanSurface* FakeOutputSurface::GetVulkanSurface() {
NOTIMPLEMENTED();
return nullptr;
}
#endif
} // namespace cc