mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-11 18:00:34 +00:00
the Android version is now able to access honeycomb rules via assets
This commit is contained in:
parent
3c3c95e072
commit
9ebd7d98d5
@ -48,6 +48,8 @@ import android.widget.FrameLayout.LayoutParams;
|
||||
import android.widget.Toast;
|
||||
import android.util.Log;
|
||||
|
||||
import java.io.InputStream;
|
||||
|
||||
public class HyperRogue extends Activity implements SensorEventListener {
|
||||
|
||||
private static final int RESULT_SETTINGS = 1;
|
||||
@ -627,6 +629,18 @@ public class HyperRogue extends Activity implements SensorEventListener {
|
||||
return bounds.width();
|
||||
}
|
||||
|
||||
public byte[] getAsset(String s) {
|
||||
try {
|
||||
InputStream is = getAssets().open(s);
|
||||
int length = is.available();
|
||||
byte[] data = new byte[length];
|
||||
is.read(data);
|
||||
return data;
|
||||
} catch (IOException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
private SensorManager mSensorManager;
|
||||
private Sensor mSensor;
|
||||
// private final float[] mAccelerometerReading = new float[3];
|
||||
|
@ -45,6 +45,7 @@ void special_log(char c);
|
||||
#include <string>
|
||||
|
||||
namespace hr {
|
||||
std::string get_asset(const std::string &str);
|
||||
void gdpush(int t);
|
||||
|
||||
void shareScore(MOBPAR_FORMAL);
|
||||
@ -242,6 +243,20 @@ Java_com_roguetemple_hyperroid_HyperRogue_initGame(MOBPAR_FORMAL) {
|
||||
|
||||
JNIEnv *tw_env; jobject tw_thiz;
|
||||
|
||||
string get_asset(const string &str) {
|
||||
jclass cls = tw_env->GetObjectClass(tw_thiz);
|
||||
jmethodID mid = tw_env->GetMethodID(cls, "getAsset", "(Ljava/lang/String;)[B");
|
||||
jobject jstr = tw_env->NewStringUTF(str.c_str());
|
||||
jbyteArray arr = (jbyteArray) tw_env->CallObjectMethod(tw_thiz, mid, jstr);
|
||||
tw_env->DeleteLocalRef(jstr);
|
||||
tw_env->DeleteLocalRef(cls);
|
||||
jsize len = tw_env->GetArrayLength(arr);
|
||||
jbyte* data = tw_env->GetByteArrayElements(arr, NULL);
|
||||
string s((char*) & (data[0]), len);
|
||||
tw_env->DeleteLocalRef(arr);
|
||||
return s;
|
||||
}
|
||||
|
||||
int textwidth(int siz, const string &str) {
|
||||
jclass cls = tw_env->GetObjectClass(tw_thiz);
|
||||
jmethodID mid = tw_env->GetMethodID(cls, "getTextWidth", "(Ljava/lang/String;I)I");
|
||||
|
@ -1,6 +1,7 @@
|
||||
#!/bin/sh
|
||||
mkdir -p app/src/main/assets/sounds
|
||||
cp ../sounds/* app/src/main/assets/sounds/
|
||||
cp ../honeycomb-rules-*.txt app/src/main/assets/
|
||||
mkdir -p app/src/main/res/raw/
|
||||
|
||||
#for x in caves crossroads desert graveyard hell icyland jungle laboratory mirror rlyeh
|
||||
|
8
reg3.cpp
8
reg3.cpp
@ -941,12 +941,17 @@ EX namespace reg3 {
|
||||
vector<int> otherpos;
|
||||
|
||||
void load_ruleset(string fname) {
|
||||
string buf;
|
||||
#if ISANDROID
|
||||
buf = get_asset(fname);
|
||||
#else
|
||||
FILE *f = fopen(fname.c_str(), "rb");
|
||||
if(!f) f = fopen((rsrcdir + fname).c_str(), "rb");
|
||||
string buf;
|
||||
buf.resize(1000000);
|
||||
int qty = fread(&buf[0], 1, 1000000, f);
|
||||
buf.resize(qty);
|
||||
fclose(f);
|
||||
#endif
|
||||
|
||||
shstream ins(decompress_string(buf));
|
||||
dynamicval<bool> q(fieldpattern::use_quotient_fp, true);
|
||||
@ -955,7 +960,6 @@ EX namespace reg3 {
|
||||
hread(ins, root);
|
||||
hread(ins, children);
|
||||
hread(ins, other);
|
||||
fclose(f);
|
||||
}
|
||||
|
||||
/** \brief address = (fieldvalue, state) */
|
||||
|
Loading…
Reference in New Issue
Block a user