2013-02-26 20:49:00 +01:00
|
|
|
// Copyright (C) 2003 Dolphin Project.
|
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, version 2.0.
|
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
// Official SVN repository and contact information can be found at
|
|
|
|
// http://code.google.com/p/dolphin-emu/
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
#include "Common.h"
|
|
|
|
#include "FileUtil.h"
|
|
|
|
|
|
|
|
#include "Core.h"
|
|
|
|
#include "Host.h"
|
|
|
|
#include "CPUDetect.h"
|
|
|
|
#include "Thread.h"
|
|
|
|
|
|
|
|
#include "PowerPC/PowerPC.h"
|
|
|
|
#include "HW/Wiimote.h"
|
|
|
|
|
|
|
|
#include "VideoBackendBase.h"
|
|
|
|
#include "ConfigManager.h"
|
|
|
|
#include "LogManager.h"
|
|
|
|
#include "BootManager.h"
|
2013-04-15 03:39:56 +02:00
|
|
|
#include "OnScreenDisplay.h"
|
|
|
|
|
2013-04-23 21:21:48 +02:00
|
|
|
// Banner loading
|
|
|
|
#include "Filesystem.h"
|
|
|
|
#include "BannerLoader.h"
|
|
|
|
#include "VolumeCreator.h"
|
|
|
|
|
2013-04-15 03:39:56 +02:00
|
|
|
#include "Android/ButtonManager.h"
|
2013-02-26 20:49:00 +01:00
|
|
|
|
|
|
|
#include <jni.h>
|
|
|
|
#include <android/log.h>
|
2013-03-20 03:53:09 +01:00
|
|
|
#include <android/native_window_jni.h>
|
|
|
|
ANativeWindow* surf;
|
2013-03-25 03:06:34 +01:00
|
|
|
int g_width, g_height;
|
2013-02-26 20:49:00 +01:00
|
|
|
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "Dolphinemu", __VA_ARGS__))
|
|
|
|
|
|
|
|
void Host_NotifyMapLoaded() {}
|
|
|
|
void Host_RefreshDSPDebuggerWindow() {}
|
|
|
|
|
|
|
|
void Host_ShowJitResults(unsigned int address){}
|
|
|
|
|
|
|
|
Common::Event updateMainFrameEvent;
|
|
|
|
void Host_Message(int Id)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void* Host_GetRenderHandle()
|
|
|
|
{
|
2013-03-20 03:53:09 +01:00
|
|
|
return surf;
|
2013-02-26 20:49:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void* Host_GetInstance() { return NULL; }
|
|
|
|
|
|
|
|
void Host_UpdateTitle(const char* title){};
|
|
|
|
|
|
|
|
void Host_UpdateLogDisplay(){}
|
|
|
|
|
|
|
|
void Host_UpdateDisasmDialog(){}
|
|
|
|
|
|
|
|
void Host_UpdateMainFrame()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void Host_UpdateBreakPointView(){}
|
|
|
|
|
|
|
|
bool Host_GetKeyState(int keycode)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Host_GetRenderWindowSize(int& x, int& y, int& width, int& height)
|
|
|
|
{
|
|
|
|
x = SConfig::GetInstance().m_LocalCoreStartupParameter.iRenderWindowXPos;
|
|
|
|
y = SConfig::GetInstance().m_LocalCoreStartupParameter.iRenderWindowYPos;
|
2013-03-25 03:06:34 +01:00
|
|
|
width = g_width;
|
|
|
|
height = g_height;
|
2013-02-26 20:49:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void Host_RequestRenderWindowSize(int width, int height) {}
|
|
|
|
void Host_SetStartupDebuggingParameters()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Host_RendererHasFocus()
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Host_ConnectWiimote(int wm_idx, bool connect) {}
|
|
|
|
|
|
|
|
void Host_SetWaitCursor(bool enable){}
|
|
|
|
|
|
|
|
void Host_UpdateStatusBar(const char* _pText, int Filed){}
|
|
|
|
|
|
|
|
void Host_SysMessage(const char *fmt, ...)
|
|
|
|
{
|
|
|
|
va_list list;
|
|
|
|
char msg[512];
|
|
|
|
|
|
|
|
va_start(list, fmt);
|
2013-05-06 06:10:58 +02:00
|
|
|
vsnprintf(msg, 512, fmt, list);
|
2013-02-26 20:49:00 +01:00
|
|
|
va_end(list);
|
|
|
|
|
|
|
|
size_t len = strlen(msg);
|
|
|
|
if (msg[len - 1] != '\n') {
|
|
|
|
msg[len - 1] = '\n';
|
|
|
|
msg[len] = '\0';
|
|
|
|
}
|
|
|
|
LOGI(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Host_SetWiiMoteConnectionState(int _State) {}
|
|
|
|
|
2013-04-15 03:39:56 +02:00
|
|
|
void OSDCallbacks(u32 UserData)
|
|
|
|
{
|
|
|
|
switch(UserData)
|
|
|
|
{
|
|
|
|
case 0: // Init
|
|
|
|
ButtonManager::Init();
|
|
|
|
break;
|
|
|
|
case 1: // Draw
|
|
|
|
ButtonManager::DrawButtons();
|
|
|
|
break;
|
|
|
|
case 2: // Shutdown
|
|
|
|
ButtonManager::Shutdown();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
WARN_LOG(COMMON, "Error, wrong OSD type");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-23 21:21:48 +02:00
|
|
|
#define DVD_BANNER_WIDTH 96
|
|
|
|
#define DVD_BANNER_HEIGHT 32
|
|
|
|
std::vector<std::string> m_volume_names;
|
|
|
|
std::vector<std::string> m_names;
|
|
|
|
|
|
|
|
bool LoadBanner(std::string filename, u32 *Banner)
|
|
|
|
{
|
|
|
|
DiscIO::IVolume* pVolume = DiscIO::CreateVolumeFromFilename(filename);
|
|
|
|
|
|
|
|
if (pVolume != NULL)
|
|
|
|
{
|
|
|
|
bool bIsWad = false;
|
|
|
|
if (DiscIO::IsVolumeWadFile(pVolume))
|
|
|
|
bIsWad = true;
|
|
|
|
|
|
|
|
m_volume_names = pVolume->GetNames();
|
|
|
|
|
|
|
|
// check if we can get some info from the banner file too
|
|
|
|
DiscIO::IFileSystem* pFileSystem = DiscIO::CreateFileSystem(pVolume);
|
|
|
|
|
|
|
|
if (pFileSystem != NULL || bIsWad)
|
|
|
|
{
|
|
|
|
DiscIO::IBannerLoader* pBannerLoader = DiscIO::CreateBannerLoader(*pFileSystem, pVolume);
|
|
|
|
|
|
|
|
if (pBannerLoader != NULL)
|
|
|
|
if (pBannerLoader->IsValid())
|
|
|
|
{
|
|
|
|
m_names = pBannerLoader->GetNames();
|
|
|
|
if (pBannerLoader->GetBanner(Banner))
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
std::string GetName(std::string filename)
|
|
|
|
{
|
|
|
|
if (!m_names.empty())
|
|
|
|
return m_names[0];
|
|
|
|
|
|
|
|
if (!m_volume_names.empty())
|
|
|
|
return m_volume_names[0];
|
|
|
|
// No usable name, return filename (better than nothing)
|
|
|
|
std::string name;
|
|
|
|
SplitPath(filename, NULL, &name, NULL);
|
|
|
|
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-02-26 20:49:00 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_UnPauseEmulation(JNIEnv *env, jobject obj)
|
2013-03-20 03:53:09 +01:00
|
|
|
{
|
|
|
|
PowerPC::Start();
|
|
|
|
}
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_PauseEmulation(JNIEnv *env, jobject obj)
|
2013-03-20 03:53:09 +01:00
|
|
|
{
|
|
|
|
PowerPC::Pause();
|
|
|
|
}
|
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_StopEmulation(JNIEnv *env, jobject obj)
|
2013-03-20 03:53:09 +01:00
|
|
|
{
|
|
|
|
PowerPC::Stop();
|
|
|
|
}
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_onTouchEvent(JNIEnv *env, jobject obj, jint Action, jfloat X, jfloat Y)
|
2013-03-20 03:53:09 +01:00
|
|
|
{
|
2013-04-15 03:39:56 +02:00
|
|
|
ButtonManager::TouchEvent(Action, X, Y);
|
2013-03-20 03:53:09 +01:00
|
|
|
}
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_onGamePadEvent(JNIEnv *env, jobject obj, jstring jDevice, jint Button, jint Action)
|
|
|
|
{
|
|
|
|
const char *Device = env->GetStringUTFChars(jDevice, NULL);
|
|
|
|
std::string strDevice = std::string(Device);
|
|
|
|
ButtonManager::GamepadEvent(strDevice, Button, Action);
|
|
|
|
env->ReleaseStringUTFChars(jDevice, Device);
|
|
|
|
}
|
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_onGamePadMoveEvent(JNIEnv *env, jobject obj, jstring jDevice, jint Axis, jfloat Value)
|
|
|
|
{
|
|
|
|
const char *Device = env->GetStringUTFChars(jDevice, NULL);
|
|
|
|
std::string strDevice = std::string(Device);
|
|
|
|
ButtonManager::GamepadAxisEvent(strDevice, Axis, Value);
|
|
|
|
env->ReleaseStringUTFChars(jDevice, Device);
|
|
|
|
}
|
2013-03-20 03:53:09 +01:00
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT jintArray JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetBanner(JNIEnv *env, jobject obj, jstring jFile)
|
2013-04-23 21:21:48 +02:00
|
|
|
{
|
|
|
|
const char *File = env->GetStringUTFChars(jFile, NULL);
|
|
|
|
jintArray Banner = env->NewIntArray(DVD_BANNER_WIDTH * DVD_BANNER_HEIGHT);
|
|
|
|
u32 uBanner[DVD_BANNER_WIDTH * DVD_BANNER_HEIGHT];
|
|
|
|
if (LoadBanner(File, uBanner))
|
|
|
|
{
|
|
|
|
env->SetIntArrayRegion(Banner, 0, DVD_BANNER_WIDTH * DVD_BANNER_HEIGHT, (jint*)uBanner);
|
|
|
|
}
|
|
|
|
env->ReleaseStringUTFChars(jFile, File);
|
|
|
|
return Banner;
|
|
|
|
}
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetTitle(JNIEnv *env, jobject obj, jstring jFile)
|
2013-04-23 21:21:48 +02:00
|
|
|
{
|
|
|
|
const char *File = env->GetStringUTFChars(jFile, NULL);
|
|
|
|
std::string Name = GetName(File);
|
|
|
|
m_names.clear();
|
|
|
|
m_volume_names.clear();
|
|
|
|
|
|
|
|
env->ReleaseStringUTFChars(jFile, File);
|
|
|
|
return env->NewStringUTF(Name.c_str());
|
|
|
|
}
|
2013-06-23 05:54:28 +02:00
|
|
|
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetVersionString(JNIEnv *env, jobject obj)
|
|
|
|
{
|
|
|
|
return env->NewStringUTF(scm_rev_str);
|
|
|
|
}
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT jstring JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_GetConfig(JNIEnv *env, jobject obj, jstring jFile, jstring jKey, jstring jValue, jstring jDefault)
|
2013-04-23 21:21:48 +02:00
|
|
|
{
|
|
|
|
IniFile ini;
|
2013-06-18 14:09:20 +02:00
|
|
|
const char *File = env->GetStringUTFChars(jFile, NULL);
|
2013-04-23 21:21:48 +02:00
|
|
|
const char *Key = env->GetStringUTFChars(jKey, NULL);
|
|
|
|
const char *Value = env->GetStringUTFChars(jValue, NULL);
|
|
|
|
const char *Default = env->GetStringUTFChars(jDefault, NULL);
|
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
ini.Load(File::GetUserPath(D_CONFIG_IDX) + std::string(File));
|
2013-04-23 21:21:48 +02:00
|
|
|
std::string value;
|
|
|
|
|
|
|
|
ini.Get(Key, Value, &value, Default);
|
2013-06-18 14:09:20 +02:00
|
|
|
|
|
|
|
env->ReleaseStringUTFChars(jFile, File);
|
2013-04-23 21:21:48 +02:00
|
|
|
env->ReleaseStringUTFChars(jKey, Key);
|
|
|
|
env->ReleaseStringUTFChars(jValue, Value);
|
|
|
|
env->ReleaseStringUTFChars(jDefault, Default);
|
|
|
|
|
|
|
|
return env->NewStringUTF(value.c_str());
|
|
|
|
}
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SetConfig(JNIEnv *env, jobject obj, jstring jFile, jstring jKey, jstring jValue, jstring jDefault)
|
2013-04-23 21:21:48 +02:00
|
|
|
{
|
|
|
|
IniFile ini;
|
2013-06-18 14:09:20 +02:00
|
|
|
const char *File = env->GetStringUTFChars(jFile, NULL);
|
2013-04-23 21:21:48 +02:00
|
|
|
const char *Key = env->GetStringUTFChars(jKey, NULL);
|
|
|
|
const char *Value = env->GetStringUTFChars(jValue, NULL);
|
|
|
|
const char *Default = env->GetStringUTFChars(jDefault, NULL);
|
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
ini.Load(File::GetUserPath(D_CONFIG_IDX) + std::string(File));
|
|
|
|
|
2013-04-23 21:21:48 +02:00
|
|
|
ini.Set(Key, Value, Default);
|
2013-06-18 14:09:20 +02:00
|
|
|
ini.Save(File::GetUserPath(D_CONFIG_IDX) + std::string(File));
|
2013-04-23 21:21:48 +02:00
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
env->ReleaseStringUTFChars(jFile, File);
|
2013-04-23 21:21:48 +02:00
|
|
|
env->ReleaseStringUTFChars(jKey, Key);
|
|
|
|
env->ReleaseStringUTFChars(jValue, Value);
|
|
|
|
env->ReleaseStringUTFChars(jDefault, Default);
|
|
|
|
}
|
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_Run(JNIEnv *env, jobject obj, jstring jFile, jobject _surf, jint _width, jint _height)
|
2013-02-26 20:49:00 +01:00
|
|
|
{
|
2013-03-20 03:53:09 +01:00
|
|
|
surf = ANativeWindow_fromSurface(env, _surf);
|
2013-03-25 03:06:34 +01:00
|
|
|
g_width = (int)_width;
|
|
|
|
g_height = (int)_height;
|
2013-04-15 03:39:56 +02:00
|
|
|
|
|
|
|
// Install our callbacks
|
|
|
|
OSD::AddCallback(OSD::OSD_INIT, OSDCallbacks, 0);
|
|
|
|
OSD::AddCallback(OSD::OSD_SHUTDOWN, OSDCallbacks, 2);
|
|
|
|
|
2013-02-26 20:49:00 +01:00
|
|
|
LogManager::Init();
|
|
|
|
SConfig::Init();
|
|
|
|
VideoBackend::PopulateList();
|
2013-04-15 03:39:56 +02:00
|
|
|
VideoBackend::ActivateBackend(SConfig::GetInstance().m_LocalCoreStartupParameter.m_strVideoBackend);
|
2013-02-26 20:49:00 +01:00
|
|
|
WiimoteReal::LoadSettings();
|
2013-04-23 21:21:48 +02:00
|
|
|
|
2013-06-18 14:09:20 +02:00
|
|
|
// Load our Android specific settings
|
|
|
|
IniFile ini;
|
|
|
|
bool onscreencontrols = true;
|
|
|
|
ini.Load(File::GetUserPath(D_CONFIG_IDX) + std::string("Dolphin.ini"));
|
|
|
|
ini.Get("Android", "ScreenControls", &onscreencontrols, true);
|
|
|
|
|
|
|
|
if (onscreencontrols)
|
|
|
|
OSD::AddCallback(OSD::OSD_ONFRAME, OSDCallbacks, 1);
|
|
|
|
|
2013-04-15 03:39:56 +02:00
|
|
|
const char *File = env->GetStringUTFChars(jFile, NULL);
|
2013-02-26 20:49:00 +01:00
|
|
|
// No use running the loop when booting fails
|
2013-03-20 03:53:09 +01:00
|
|
|
if ( BootManager::BootCore( File ) )
|
2013-02-26 20:49:00 +01:00
|
|
|
while (PowerPC::GetState() != PowerPC::CPU_POWERDOWN)
|
|
|
|
updateMainFrameEvent.Wait();
|
|
|
|
|
|
|
|
WiimoteReal::Shutdown();
|
|
|
|
VideoBackend::ClearList();
|
|
|
|
SConfig::Shutdown();
|
|
|
|
LogManager::Shutdown();
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|