mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
This also fixes an issue where eglChooseConfig was only being called in InitializeOneOff, which is only called once per process. This CL makes choosing the config happen once per GLSurface instead, which will ultimately permit apps to create multiple native_viewports with different surface configurations on the same display. The eglDisplay object is still a global, though. R=abarth@chromium.org, viettrungluu@chromium.org, jamesr@chromium.org Review URL: https://codereview.chromium.org/1168993002.
94 lines
2.5 KiB
C++
94 lines
2.5 KiB
C++
// Copyright 2015 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 "sky/shell/gpu/rasterizer.h"
|
|
|
|
#include "base/trace_event/trace_event.h"
|
|
#include "sky/shell/gpu/ganesh_context.h"
|
|
#include "sky/shell/gpu/ganesh_surface.h"
|
|
#include "third_party/skia/include/core/SkCanvas.h"
|
|
#include "third_party/skia/include/core/SkPicture.h"
|
|
#include "ui/gl/gl_bindings.h"
|
|
#include "ui/gl/gl_context.h"
|
|
#include "ui/gl/gl_share_group.h"
|
|
#include "ui/gl/gl_surface.h"
|
|
|
|
namespace sky {
|
|
namespace shell {
|
|
namespace {
|
|
|
|
gfx::Size GetSize(SkPicture* picture) {
|
|
const SkRect& rect = picture->cullRect();
|
|
return gfx::Size(rect.width(), rect.height());
|
|
}
|
|
|
|
} // namespace
|
|
|
|
Rasterizer::Rasterizer()
|
|
: share_group_(new gfx::GLShareGroup()), weak_factory_(this) {
|
|
}
|
|
|
|
Rasterizer::~Rasterizer() {
|
|
}
|
|
|
|
base::WeakPtr<Rasterizer> Rasterizer::GetWeakPtr() {
|
|
return weak_factory_.GetWeakPtr();
|
|
}
|
|
|
|
void Rasterizer::OnAcceleratedWidgetAvailable(gfx::AcceleratedWidget widget) {
|
|
surface_ = gfx::GLSurface::CreateViewGLSurface(widget,
|
|
gfx::SurfaceConfiguration());
|
|
CHECK(surface_) << "GLSurface required.";
|
|
}
|
|
|
|
void Rasterizer::Draw(skia::RefPtr<SkPicture> picture) {
|
|
TRACE_EVENT0("sky", "Rasterizer::Draw");
|
|
|
|
if (!surface_)
|
|
return;
|
|
|
|
gfx::Size size = GetSize(picture.get());
|
|
if (size.IsEmpty())
|
|
return;
|
|
|
|
EnsureGLContext();
|
|
CHECK(context_->MakeCurrent(surface_.get()));
|
|
EnsureGaneshSurface(size);
|
|
|
|
DrawPicture(picture.get());
|
|
surface_->SwapBuffers();
|
|
}
|
|
|
|
void Rasterizer::DrawPicture(SkPicture* picture) {
|
|
TRACE_EVENT0("sky", "Rasterizer::DrawPicture");
|
|
SkCanvas* canvas = ganesh_surface_->canvas();
|
|
canvas->drawPicture(picture);
|
|
canvas->flush();
|
|
}
|
|
|
|
void Rasterizer::OnOutputSurfaceDestroyed() {
|
|
ganesh_surface_.reset();
|
|
ganesh_context_.reset();
|
|
context_ = nullptr;
|
|
surface_ = nullptr;
|
|
}
|
|
|
|
void Rasterizer::EnsureGLContext() {
|
|
if (context_)
|
|
return;
|
|
context_ = gfx::GLContext::CreateGLContext(share_group_.get(), surface_.get(),
|
|
gfx::PreferIntegratedGpu);
|
|
CHECK(context_) << "GLContext required.";
|
|
CHECK(context_->MakeCurrent(surface_.get()));
|
|
ganesh_context_.reset(new GaneshContext(context_.get()));
|
|
}
|
|
|
|
void Rasterizer::EnsureGaneshSurface(const gfx::Size& size) {
|
|
if (!ganesh_surface_ || ganesh_surface_->size() != size)
|
|
ganesh_surface_.reset(new GaneshSurface(ganesh_context_.get(), size));
|
|
}
|
|
|
|
} // namespace shell
|
|
} // namespace sky
|