mirror of
https://github.com/hrydgard/ppsspp.git
synced 2025-01-06 13:18:46 +00:00
79 lines
2.4 KiB
C++
79 lines
2.4 KiB
C++
#include "Common/GPU/OpenGL/GLFeatures.h"
|
|
#include "Common/GPU/thin3d_create.h"
|
|
|
|
#include "Common/Log.h"
|
|
#include "Common/System/System.h"
|
|
#include "Common/VR/PPSSPPVR.h"
|
|
#include "AndroidEGLContext.h"
|
|
#include "GL/GLInterface/EGLAndroid.h"
|
|
#include "Core/Config.h"
|
|
#include "Core/ConfigValues.h"
|
|
#include "Core/System.h"
|
|
|
|
bool AndroidEGLGraphicsContext::InitFromRenderThread(ANativeWindow *wnd, int desiredBackbufferSizeX, int desiredBackbufferSizeY, int backbufferFormat, int androidVersion) {
|
|
INFO_LOG(G3D, "AndroidEGLGraphicsContext::Init()");
|
|
wnd_ = wnd;
|
|
gl = HostGL_CreateGLInterface();
|
|
if (!gl) {
|
|
ERROR_LOG(G3D, "ERROR: Failed to create GL interface");
|
|
return false;
|
|
}
|
|
int backbufferWidth = desiredBackbufferSizeX;
|
|
int backbufferHeight = desiredBackbufferSizeY;
|
|
INFO_LOG(G3D, "EGL interface created. Desired backbuffer size: %dx%d", backbufferWidth, backbufferHeight);
|
|
|
|
// Apparently we still have to set this through Java through setFixedSize on the bufferHolder for it to take effect...
|
|
gl->SetBackBufferDimensions(backbufferWidth, backbufferHeight);
|
|
gl->SetMode(MODE_DETECT);
|
|
|
|
bool use565 = false;
|
|
|
|
// This workaround seems only be needed on some really old devices.
|
|
if (androidVersion < ANDROID_VERSION_ICS) {
|
|
switch (backbufferFormat) {
|
|
case 4: // PixelFormat.RGB_565
|
|
use565 = true;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!gl->Create(wnd, false, use565)) {
|
|
ERROR_LOG(G3D, "EGL creation failed! (use565=%d)", (int)use565);
|
|
// TODO: What do we do now?
|
|
delete gl;
|
|
return false;
|
|
}
|
|
gl->MakeCurrent();
|
|
if (gl->GetMode() == GLInterfaceMode::MODE_OPENGL)
|
|
SetGLCoreContext(!IsVRBuild());
|
|
CheckGLExtensions();
|
|
draw_ = Draw::T3DCreateGLContext();
|
|
SetGPUBackend(GPUBackend::OPENGL);
|
|
renderManager_ = (GLRenderManager *)draw_->GetNativeObject(Draw::NativeObject::RENDER_MANAGER);
|
|
renderManager_->SetInflightFrames(g_Config.iInflightFrames);
|
|
bool success = draw_->CreatePresets(); // There will always be a GLSL compiler capable of compiling these.
|
|
_assert_msg_(success, "Failed to compile preset shaders");
|
|
return true;
|
|
}
|
|
|
|
void AndroidEGLGraphicsContext::ShutdownFromRenderThread() {
|
|
INFO_LOG(G3D, "AndroidEGLGraphicsContext::Shutdown");
|
|
renderManager_->WaitUntilQueueIdle();
|
|
renderManager_ = nullptr; // owned by draw_.
|
|
delete draw_;
|
|
draw_ = nullptr;
|
|
}
|
|
|
|
void AndroidEGLGraphicsContext::Shutdown() {
|
|
gl->ClearCurrent();
|
|
gl->Shutdown();
|
|
delete gl;
|
|
ANativeWindow_release(wnd_);
|
|
}
|
|
|
|
void AndroidEGLGraphicsContext::SwapBuffers() {
|
|
gl->Swap();
|
|
}
|