diff --git a/Source/Android/.idea/workspace.xml b/Source/Android/.idea/workspace.xml
index 2a518c17f3..dee70dcfd4 100644
--- a/Source/Android/.idea/workspace.xml
+++ b/Source/Android/.idea/workspace.xml
@@ -29,7 +29,7 @@
-
+
@@ -103,65 +103,42 @@
-
+
-
-
-
-
-
-
-
-
-
-
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
@@ -173,6 +150,11 @@
+
+
+
+
+
@@ -184,22 +166,22 @@
@@ -253,6 +235,7 @@
+
@@ -288,18 +271,13 @@
-
-
-
-
-
+
-
@@ -341,23 +319,26 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
@@ -386,6 +367,19 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
@@ -436,19 +430,6 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -553,29 +534,29 @@
-
-
-
-
-
-
-
-
-
-
-
-
+
-
-
+
+
+
+
+
+
+
+
+
+
-
-
+
+
+
+
+
@@ -640,125 +621,106 @@
-
-
-
-
-
-
-
-
-
-
+
-
-
-
-
+
-
-
-
+
-
-
-
+
-
-
-
+
-
+
-
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
-
-
-
-
+
-
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
-
+
-
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/Source/Android/AndroidManifest.xml b/Source/Android/AndroidManifest.xml
index 3b4d735b37..802f2f6cf6 100644
--- a/Source/Android/AndroidManifest.xml
+++ b/Source/Android/AndroidManifest.xml
@@ -35,6 +35,11 @@
android:label="@string/app_name"
android:configChanges="orientation|locale|keyboard|keyboardHidden|navigation|fontScale|uiMode" >
+
+
diff --git a/Source/Android/assets/GCPadNew.ini b/Source/Android/assets/GCPadNew.ini
index cb828f9960..3c22ed5a2e 100644
--- a/Source/Android/assets/GCPadNew.ini
+++ b/Source/Android/assets/GCPadNew.ini
@@ -2,28 +2,28 @@
Device = Android/0/Touchscreen
Buttons/A = Button 0
Buttons/B = Button 1
-Buttons/X = C
-Buttons/Y = S
-Buttons/Z = D
+Buttons/X = Button 3
+Buttons/Y = Button 4
+Buttons/Z = Button 5
Buttons/Start = Button 2
-Main Stick/Up = Up
-Main Stick/Down = Down
-Main Stick/Left = Left
-Main Stick/Right = Right
+Main Stick/Up = Axis 10
+Main Stick/Down = Axis 11
+Main Stick/Left = Axis 12
+Main Stick/Right = Axis 13
Main Stick/Modifier = Shift_L
Main Stick/Modifier/Range = 50.000000
-C-Stick/Up = I
-C-Stick/Down = K
-C-Stick/Left = J
-C-Stick/Right = L
+C-Stick/Up = Axis 14
+C-Stick/Down = Axis 15
+C-Stick/Left = Axis 16
+C-Stick/Right = Axis 17
C-Stick/Modifier = Control_L
C-Stick/Modifier/Range = 50.000000
-Triggers/L = Q
-Triggers/R = W
-D-Pad/Up = T
-D-Pad/Down = G
-D-Pad/Left = F
-D-Pad/Right = H
+Triggers/L = Axis 18
+Triggers/R = Axis 19
+D-Pad/Up = Button 6
+D-Pad/Down = Button 7
+D-Pad/Left = Button 8
+D-Pad/Right = Button 9
[GCPad2]
[GCPad3]
[GCPad4]
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/DolphinEmulator.java b/Source/Android/src/org/dolphinemu/dolphinemu/DolphinEmulator.java
index bee3e5fcca..d8432b7e22 100644
--- a/Source/Android/src/org/dolphinemu/dolphinemu/DolphinEmulator.java
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/DolphinEmulator.java
@@ -7,10 +7,13 @@ import android.os.Bundle;
import android.os.Environment;
import android.util.DisplayMetrics;
import android.util.Log;
+import android.view.InputDevice;
+import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.WindowManager;
import java.io.*;
+import java.util.List;
public class DolphinEmulator extends Activity
{
@@ -20,19 +23,6 @@ public class DolphinEmulator extends Activity
private float screenWidth;
private float screenHeight;
- public static native void onTouchEvent(int Action, float X, float Y);
-
- static
- {
- try
- {
- System.loadLibrary("dolphin-emu-nogui");
- }
- catch (Exception ex)
- {
- Log.w("me", ex.toString());
- }
- }
private void CopyAsset(String asset, String output) {
InputStream in = null;
OutputStream out = null;
@@ -49,6 +39,7 @@ public class DolphinEmulator extends Activity
Log.e("tag", "Failed to copy asset file: " + asset, e);
}
}
+
private void copyFile(InputStream in, OutputStream out) throws IOException {
byte[] buffer = new byte[1024];
int read;
@@ -62,21 +53,21 @@ public class DolphinEmulator extends Activity
{
super.onStop();
if (Running)
- NativeGLSurfaceView.StopEmulation();
+ NativeLibrary.StopEmulation();
}
@Override
public void onPause()
{
super.onPause();
if (Running)
- NativeGLSurfaceView.PauseEmulation();
+ NativeLibrary.PauseEmulation();
}
@Override
public void onResume()
{
super.onResume();
if (Running)
- NativeGLSurfaceView.UnPauseEmulation();
+ NativeLibrary.UnPauseEmulation();
}
/** Called when the activity is first created. */
@@ -158,14 +149,46 @@ public class DolphinEmulator extends Activity
float ScreenX = ((X / screenWidth) * 2.0f) - 1.0f;
float ScreenY = ((Y / screenHeight) * -2.0f) + 1.0f;
- onTouchEvent(Action, ScreenX, ScreenY);
+ NativeLibrary.onTouchEvent(Action, ScreenX, ScreenY);
return false;
}
-
- public boolean overrideKeys()
- {
- return false;
- }
+
+ // Gets button presses
+ @Override
+ public boolean dispatchKeyEvent(KeyEvent event) {
+ int action = 0;
+ switch (event.getAction()) {
+ case KeyEvent.ACTION_DOWN:
+ action = 0;
+ break;
+ case KeyEvent.ACTION_UP:
+ action = 1;
+ break;
+ default:
+ break;
+ }
+ InputDevice input = event.getDevice();
+ NativeLibrary.onGamePadEvent(input.getDescriptor(), event.getKeyCode(), action);
+ return true;
+ }
+
+ @Override
+ public boolean dispatchGenericMotionEvent(MotionEvent event) {
+ if (((event.getSource() & InputDevice.SOURCE_CLASS_JOYSTICK) == 0)) {
+ return super.dispatchGenericMotionEvent(event);
+ }
+
+ InputDevice input = event.getDevice();
+ List motions = input.getMotionRanges();
+ for (int a = 0; a < motions.size(); ++a)
+ {
+ InputDevice.MotionRange range;
+ range = motions.get(a);
+ NativeLibrary.onGamePadMoveEvent(input.getDescriptor(), range.getAxis(), event.getAxisValue(range.getAxis()));
+ }
+
+ return true;
+ }
}
\ No newline at end of file
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/GameListItem.java b/Source/Android/src/org/dolphinemu/dolphinemu/GameListItem.java
index 87137db48d..3018300b12 100644
--- a/Source/Android/src/org/dolphinemu/dolphinemu/GameListItem.java
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/GameListItem.java
@@ -1,33 +1,19 @@
package org.dolphinemu.dolphinemu;
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
-import android.util.Log;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
public class GameListItem implements Comparable{
private String name;
private String data;
private String path;
private Bitmap image;
- public static native int[] GetBanner(String filename);
- public static native String GetTitle(String filename);
- static
- {
- try
- {
- System.loadLibrary("dolphin-emu-nogui");
- }
- catch (Exception ex)
- {
- Log.w("me", ex.toString());
- }
- }
-
+
public GameListItem(Context ctx, String n,String d,String p)
{
name = n;
@@ -36,7 +22,7 @@ public class GameListItem implements Comparable{
File file = new File(path);
if (!file.isDirectory())
{
- int[] Banner = GetBanner(path);
+ int[] Banner = NativeLibrary.GetBanner(path);
if (Banner[0] == 0)
{
try {
@@ -50,7 +36,7 @@ public class GameListItem implements Comparable{
}
else
image = Bitmap.createBitmap(Banner, 96, 32, Bitmap.Config.ARGB_8888);
- name = GetTitle(path);
+ name = NativeLibrary.GetTitle(path);
}
}
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/GameListView.java b/Source/Android/src/org/dolphinemu/dolphinemu/GameListView.java
index 314e8e0ae5..ac1329f6a9 100644
--- a/Source/Android/src/org/dolphinemu/dolphinemu/GameListView.java
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/GameListView.java
@@ -24,22 +24,18 @@ public class GameListView extends ListActivity {
private SideMenuAdapter mAdapter;
private static GameListView me;
- public static native String GetConfig(String Key, String Value, String Default);
- public static native void SetConfig(String Key, String Value, String Default);
enum keyTypes {TYPE_STRING, TYPE_BOOL};
private void Fill()
{
-
-
this.setTitle("Game List");
Listfls = new ArrayList();
- String Directories = GetConfig("General", "GCMPathes", "0");
+ String Directories = NativeLibrary.GetConfig("Dolphin.ini", "General", "GCMPathes", "0");
int intDirectories = Integer.parseInt(Directories);
for (int a = 0; a < intDirectories; ++a)
{
- String BrowseDir = GetConfig("General", "GCMPath" + Integer.toString(a), "");
+ String BrowseDir = NativeLibrary.GetConfig("Dolphin.ini", "General", "GCMPath" + Integer.toString(a), "");
File currentDir = new File(BrowseDir);
File[]dirs = currentDir.listFiles();
try
@@ -101,11 +97,11 @@ public class GameListView extends ListActivity {
{
String FileName = data.getStringExtra("Select");
Toast.makeText(this, "Folder Selected: " + FileName, Toast.LENGTH_SHORT).show();
- String Directories = GetConfig("General", "GCMPathes", "0");
+ String Directories = NativeLibrary.GetConfig("Dolphin.ini", "General", "GCMPathes", "0");
int intDirectories = Integer.parseInt(Directories);
Directories = Integer.toString(intDirectories + 1);
- SetConfig("General", "GCMPathes", Directories);
- SetConfig("General", "GCMPath" + Integer.toString(intDirectories), FileName);
+ NativeLibrary.SetConfig("Dolphin.ini", "General", "GCMPathes", Directories);
+ NativeLibrary.SetConfig("Dolphin.ini", "General", "GCMPath" + Integer.toString(intDirectories), FileName);
Fill();
}
@@ -142,16 +138,19 @@ public class GameListView extends ListActivity {
{
case TYPE_STRING:
String strPref = prefs.getString(Keys[a], "");
- SetConfig(Key, Value, strPref);
+ NativeLibrary.SetConfig("Dolphin.ini", Key, Value, strPref);
break;
case TYPE_BOOL:
boolean boolPref = prefs.getBoolean(Keys[a], true);
- SetConfig(Key, Value, boolPref ? "True" : "False");
+ NativeLibrary.SetConfig("Dolphin.ini", Key, Value, boolPref ? "True" : "False");
break;
}
}
break;
+ case 3: // Gamepad settings
+ /* Do Nothing */
+ break;
}
}
@@ -169,6 +168,7 @@ public class GameListView extends ListActivity {
Listdir = new ArrayList();
dir.add(new SideMenuItem("Browse Folder", 0));
dir.add(new SideMenuItem("Settings", 1));
+ dir.add(new SideMenuItem("Gamepad Config", 2));
ListView mList = new ListView(this);
mAdapter = new SideMenuAdapter(this,R.layout.sidemenu,dir);
@@ -193,6 +193,11 @@ public class GameListView extends ListActivity {
Intent SettingIntent = new Intent(me, PrefsActivity.class);
startActivityForResult(SettingIntent, 2);
break;
+ case 2:
+ Toast.makeText(me, "Loading up settings", Toast.LENGTH_SHORT).show();
+ Intent ConfigIntent = new Intent(me, InputConfigActivity.class);
+ startActivityForResult(ConfigIntent, 3);
+ break;
default:
break;
}
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigActivity.java b/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigActivity.java
new file mode 100644
index 0000000000..1df812b830
--- /dev/null
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigActivity.java
@@ -0,0 +1,181 @@
+package org.dolphinemu.dolphinemu;
+
+import android.app.Activity;
+import android.app.ListActivity;
+import android.content.Intent;
+import android.os.Bundle;
+import android.util.Log;
+import android.view.InputDevice;
+import android.view.KeyEvent;
+import android.view.MotionEvent;
+import android.view.View;
+import android.widget.ListView;
+import android.widget.Toast;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * Copyright 2013 Dolphin Emulator Project
+ * Licensed under GPLv2
+ * Refer to the license.txt file included.
+ */
+public class InputConfigActivity extends ListActivity {
+ private InputConfigAdapter adapter;
+ private int configPosition = 0;
+ boolean Configuring = false;
+ boolean firstEvent = true;
+
+ @Override
+ public void onCreate(Bundle savedInstanceState)
+ {
+ super.onCreate(savedInstanceState);
+ List Input = new ArrayList();
+ int a = 0;
+
+ Input.add(a++, new InputConfigItem("Draw on-screen controls", "Android-ScreenControls", "True"));
+ Input.add(a++, new InputConfigItem("Button A", "Android-InputA"));
+ Input.add(a++, new InputConfigItem("Button B", "Android-InputB"));
+ Input.add(a++, new InputConfigItem("Button Start", "Android-InputStart"));
+ Input.add(a++, new InputConfigItem("Button X", "Android-InputX"));
+ Input.add(a++, new InputConfigItem("Button Y", "Android-InputY"));
+ Input.add(a++, new InputConfigItem("Button Z", "Android-InputZ"));
+ Input.add(a++, new InputConfigItem("D-Pad Up", "Android-DPadUp"));
+ Input.add(a++, new InputConfigItem("D-Pad Down", "Android-DPadDown"));
+ Input.add(a++, new InputConfigItem("D-Pad Left", "Android-DPadLeft"));
+ Input.add(a++, new InputConfigItem("D-Pad Right", "Android-DPadRight"));
+ Input.add(a++, new InputConfigItem("Main Stick Up", "Android-MainUp"));
+ Input.add(a++, new InputConfigItem("Main Stick Down", "Android-MainDown"));
+ Input.add(a++, new InputConfigItem("Main Stick Left", "Android-MainLeft"));
+ Input.add(a++, new InputConfigItem("Main Stick Right", "Android-MainRight"));
+ Input.add(a++, new InputConfigItem("C Stick Up", "Android-CStickUp"));
+ Input.add(a++, new InputConfigItem("C Stick Down", "Android-CStickDown"));
+ Input.add(a++, new InputConfigItem("C Stick Left", "Android-CStickLeft"));
+ Input.add(a++, new InputConfigItem("C Stick Right", "Android-CStickRight"));
+ Input.add(a++, new InputConfigItem("Trigger L", "Android-InputL"));
+ Input.add(a++, new InputConfigItem("Trigger R", "Android-InputR"));
+
+ adapter = new InputConfigAdapter(this,R.layout.folderbrowser, Input);
+ this.setListAdapter(adapter);
+ }
+ @Override
+ protected void onListItemClick(ListView l, View v, int position, long id) {
+ super.onListItemClick(l, v, position, id);
+ InputConfigItem o = adapter.getItem(position);
+ switch(position)
+ {
+ case 0: // On screen controls
+ String newBind;
+ if (o.getBind() == "True")
+ {
+ Toast.makeText(this, "Not Drawing on screen controls", Toast.LENGTH_SHORT).show();
+ newBind = "False";
+ }
+ else
+ {
+ Toast.makeText(this, "Drawing on screen controls", Toast.LENGTH_SHORT).show();
+ newBind = "True";
+ }
+ adapter.remove(o);
+ o.setBind(newBind);
+ adapter.insert(o, position);
+ break;
+ default: // gamepad controls
+ Toast.makeText(this, "Press button to configure " + o.getName(), Toast.LENGTH_SHORT).show();
+ configPosition = position;
+ Configuring = true;
+ firstEvent = true;
+ break;
+ }
+
+ }
+ static ArrayList m_values = new ArrayList();
+ // Gets move(triggers, joystick) events
+ void AssignBind(String bind)
+ {
+ InputConfigItem o = adapter.getItem(configPosition);
+ adapter.remove(o);
+ o.setBind(bind);
+ adapter.insert(o, configPosition);
+ }
+
+ @Override
+ public boolean dispatchGenericMotionEvent(MotionEvent event) {
+ if (((event.getSource() & InputDevice.SOURCE_CLASS_JOYSTICK) == 0)) {
+ return super.dispatchGenericMotionEvent(event);
+ }
+ InputDevice input = event.getDevice();
+ List motions = input.getMotionRanges();
+ if (Configuring)
+ {
+ if (firstEvent)
+ {
+ m_values.clear();
+ for (int a = 0; a < motions.size(); ++a)
+ {
+ InputDevice.MotionRange range = motions.get(a);
+ m_values.add(event.getAxisValue(range.getAxis()));
+ }
+ firstEvent = false;
+ }
+ else
+ {
+ for (int a = 0; a < motions.size(); ++a)
+ {
+ InputDevice.MotionRange range;
+ range = motions.get(a);
+ if (m_values.get(a) > (event.getAxisValue(range.getAxis()) + 0.5f))
+ {
+ AssignBind("Device '" + input.getDescriptor() + "'-Axis " + range.getAxis() + "-");
+ Configuring = false;
+ }
+ else if (m_values.get(a) < (event.getAxisValue(range.getAxis()) - 0.5f))
+ {
+ AssignBind("Device '" + input.getDescriptor() + "'-Axis " + range.getAxis() + "+");
+ Configuring = false;
+ }
+ }
+ }
+ }
+ return true;
+ }
+
+ // Gets button presses
+ @Override
+ public boolean dispatchKeyEvent(KeyEvent event) {
+ Log.w("Dolphinemu", "Got Event " + event.getAction());
+ switch (event.getAction()) {
+ case KeyEvent.ACTION_DOWN:
+ case KeyEvent.ACTION_UP:
+ if (Configuring)
+ {
+ InputDevice input = event.getDevice();
+ AssignBind("Device '" + input.getDescriptor() + "'-Button " + event.getKeyCode());
+ Configuring = false;
+ return true;
+ }
+ default:
+ break;
+ }
+
+ return super.dispatchKeyEvent(event);
+ }
+
+ @Override
+ public void onBackPressed() {
+ for (int a = 0; a < adapter.getCount(); ++a)
+ {
+ InputConfigItem o = adapter.getItem(a);
+ String config = o.getConfig();
+ String bind = o.getBind();
+ String ConfigValues[] = config.split("-");
+ String Key = ConfigValues[0];
+ String Value = ConfigValues[1];
+ NativeLibrary.SetConfig("Dolphin.ini", Key, Value, bind);
+ }
+ Intent intent = new Intent();
+ setResult(Activity.RESULT_OK, intent);
+ this.finish();
+ super.onBackPressed();
+ }
+}
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigAdapter.java b/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigAdapter.java
new file mode 100644
index 0000000000..4430126d46
--- /dev/null
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigAdapter.java
@@ -0,0 +1,56 @@
+package org.dolphinemu.dolphinemu;
+
+import android.content.Context;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.ArrayAdapter;
+import android.widget.TextView;
+
+import java.util.List;
+
+/**
+ * Copyright 2013 Dolphin Emulator Project
+ * Licensed under GPLv2
+ * Refer to the license.txt file included.
+ */
+public class InputConfigAdapter extends ArrayAdapter {
+ private Context c;
+ private int id;
+ private List items;
+
+ public InputConfigAdapter(Context context, int textViewResourceId,
+ List objects) {
+ super(context, textViewResourceId, objects);
+ c = context;
+ id = textViewResourceId;
+ items = objects;
+ }
+
+ public InputConfigItem getItem(int i)
+ {
+ return items.get(i);
+ }
+ @Override
+ public View getView(int position, View convertView, ViewGroup parent) {
+ View v = convertView;
+ if (v == null) {
+ LayoutInflater vi = (LayoutInflater)c.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
+ v = vi.inflate(id, null);
+ }
+ final InputConfigItem o = items.get(position);
+ if (o != null) {
+ TextView t1 = (TextView) v.findViewById(R.id.TextView01);
+ TextView t2 = (TextView) v.findViewById(R.id.TextView02);
+
+ if(t1!=null)
+ t1.setText(o.getName());
+ if(t2!=null)
+ t2.setText(o.getBind());
+ }
+ return v;
+ }
+
+
+
+}
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigItem.java b/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigItem.java
new file mode 100644
index 0000000000..7511406dc9
--- /dev/null
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/InputConfigItem.java
@@ -0,0 +1,56 @@
+package org.dolphinemu.dolphinemu;
+
+/**
+ * Copyright 2013 Dolphin Emulator Project
+ * Licensed under GPLv2
+ * Refer to the license.txt file included.
+ */
+public class InputConfigItem implements Comparable{
+ private String m_name;
+ private String m_Config;
+ private String m_bind;
+
+ private void Init(String n, String c, String d)
+ {
+ m_name = n;
+ m_Config = c;
+ String ConfigValues[] = m_Config.split("-");
+ String Key = ConfigValues[0];
+ String Value = ConfigValues[1];
+ m_bind = NativeLibrary.GetConfig("Dolphin.ini", Key, Value, d);
+ }
+
+ public InputConfigItem(String n, String c, String d)
+ {
+ Init(n, c, d);
+ }
+
+ public InputConfigItem(String n, String c)
+ {
+ Init(n, c, "None");
+ }
+ public String getName()
+ {
+ return m_name;
+ }
+ public String getConfig()
+ {
+ return m_Config;
+ }
+ public String getBind()
+ {
+ return m_bind;
+ }
+ public void setBind(String b)
+ {
+ m_bind = b;
+ }
+
+ public int compareTo(InputConfigItem o)
+ {
+ if(this.m_name != null)
+ return this.m_name.toLowerCase().compareTo(o.getName().toLowerCase());
+ else
+ throw new IllegalArgumentException();
+ }
+}
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/NativeGLSurfaceView.java b/Source/Android/src/org/dolphinemu/dolphinemu/NativeGLSurfaceView.java
index 25c7ace0a0..8a8041a08b 100644
--- a/Source/Android/src/org/dolphinemu/dolphinemu/NativeGLSurfaceView.java
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/NativeGLSurfaceView.java
@@ -1,9 +1,6 @@
package org.dolphinemu.dolphinemu;
import android.content.Context;
-import android.opengl.GLSurfaceView;
-import android.util.Log;
-import android.view.Surface;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
@@ -14,23 +11,6 @@ public class NativeGLSurfaceView extends SurfaceView {
static private boolean Created = false;
static private float width;
static private float height;
-
- public static native void main(String File, Surface surf, int width, int height);
- public static native void UnPauseEmulation();
- public static native void PauseEmulation();
- public static native void StopEmulation();
-
- static
- {
- try
- {
- System.loadLibrary("dolphin-emu-nogui");
- }
- catch (Exception ex)
- {
- Log.w("me", ex.toString());
- }
- }
public NativeGLSurfaceView(Context context) {
super(context);
@@ -40,7 +20,7 @@ public class NativeGLSurfaceView extends SurfaceView {
{
@Override
public void run() {
- main(FileName, getHolder().getSurface(), (int)width, (int)height);
+ NativeLibrary.Run(FileName, getHolder().getSurface(), (int)width, (int)height);
}
};
getHolder().addCallback(new SurfaceHolder.Callback() {
diff --git a/Source/Android/src/org/dolphinemu/dolphinemu/NativeLibrary.java b/Source/Android/src/org/dolphinemu/dolphinemu/NativeLibrary.java
new file mode 100644
index 0000000000..52918a040a
--- /dev/null
+++ b/Source/Android/src/org/dolphinemu/dolphinemu/NativeLibrary.java
@@ -0,0 +1,36 @@
+package org.dolphinemu.dolphinemu;
+
+import android.util.Log;
+import android.view.Surface;
+
+/**
+ * Copyright 2013 Dolphin Emulator Project
+ * Licensed under GPLv2
+ * Refer to the license.txt file included.
+ */
+public class NativeLibrary {
+ public static native void onTouchEvent(int Action, float X, float Y);
+ public static native void onGamePadEvent(String Device, int Button, int Action);
+ public static native void onGamePadMoveEvent(String Device, int Axis, float Value);
+ public static native String GetConfig(String configFile, String Key, String Value, String Default);
+ public static native void SetConfig(String configFile, String Key, String Value, String Default);
+ public static native int[] GetBanner(String filename);
+ public static native String GetTitle(String filename);
+
+ public static native void Run(String File, Surface surf, int width, int height);
+ public static native void UnPauseEmulation();
+ public static native void PauseEmulation();
+ public static native void StopEmulation();
+
+ static
+ {
+ try
+ {
+ System.loadLibrary("dolphin-emu-nogui");
+ }
+ catch (Exception ex)
+ {
+ Log.w("me", ex.toString());
+ }
+ }
+}
diff --git a/Source/Core/DolphinWX/CMakeLists.txt b/Source/Core/DolphinWX/CMakeLists.txt
index e3f8789634..940f05d811 100644
--- a/Source/Core/DolphinWX/CMakeLists.txt
+++ b/Source/Core/DolphinWX/CMakeLists.txt
@@ -92,6 +92,7 @@ if(wxWidgets_FOUND)
else()
if(ANDROID)
set(SRCS Src/Android/TextureLoader.cpp
+ Src/Android/ButtonManager.cpp
Src/MainAndroid.cpp)
else()
set(SRCS Src/MainNoGUI.cpp)
diff --git a/Source/Core/DolphinWX/Src/Android/ButtonManager.cpp b/Source/Core/DolphinWX/Src/Android/ButtonManager.cpp
new file mode 100644
index 0000000000..15cc371126
--- /dev/null
+++ b/Source/Core/DolphinWX/Src/Android/ButtonManager.cpp
@@ -0,0 +1,223 @@
+// 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
+#include "GLInterface.h"
+#include "Android/TextureLoader.h"
+#include "Android/ButtonManager.h"
+
+extern void DrawButton(GLuint tex, float *coords);
+
+namespace ButtonManager
+{
+ std::vector