v0.3.4: more language button work

This commit is contained in:
Evan Debenham
2016-01-29 01:35:54 -05:00
committed by Evan Debenham
parent e27c0fba11
commit 31a8e50754
4 changed files with 90 additions and 45 deletions
@@ -20,9 +20,8 @@
*/ */
package com.shatteredpixel.shatteredpixeldungeon; package com.shatteredpixel.shatteredpixeldungeon;
import com.watabou.noosa.Game;
import android.content.SharedPreferences; import android.content.SharedPreferences;
import com.watabou.noosa.Game;
enum Preferences { enum Preferences {
@@ -42,6 +41,7 @@ enum Preferences {
public static final String KEY_FLIPTOOLBAR = "flipped_ui"; public static final String KEY_FLIPTOOLBAR = "flipped_ui";
public static final String KEY_FLIPTAGS = "flip_tags"; public static final String KEY_FLIPTAGS = "flip_tags";
public static final String KEY_BARMODE = "toolbar_mode"; public static final String KEY_BARMODE = "toolbar_mode";
public static final String KEY_LANG = "language";
public static final String KEY_INTRO = "intro"; public static final String KEY_INTRO = "intro";
public static final String KEY_BRIGHTNESS = "brightness"; public static final String KEY_BRIGHTNESS = "brightness";
public static final String KEY_VERSION = "version"; public static final String KEY_VERSION = "version";
@@ -20,21 +20,22 @@
*/ */
package com.shatteredpixel.shatteredpixeldungeon; package com.shatteredpixel.shatteredpixeldungeon;
import javax.microedition.khronos.opengles.GL10;
import android.annotation.SuppressLint; import android.annotation.SuppressLint;
import android.content.pm.ActivityInfo; import android.content.pm.ActivityInfo;
import android.os.Bundle; import android.os.Bundle;
import android.util.DisplayMetrics; import android.util.DisplayMetrics;
import android.util.Log; import android.util.Log;
import android.view.View; import android.view.View;
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
import com.watabou.noosa.Game;
import com.watabou.noosa.audio.Music;
import com.watabou.noosa.audio.Sample;
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene; import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
import com.shatteredpixel.shatteredpixeldungeon.scenes.PixelScene; import com.shatteredpixel.shatteredpixeldungeon.scenes.PixelScene;
import com.shatteredpixel.shatteredpixeldungeon.scenes.TitleScene; import com.shatteredpixel.shatteredpixeldungeon.scenes.TitleScene;
import com.watabou.noosa.Game;
import com.watabou.noosa.audio.Music;
import com.watabou.noosa.audio.Sample;
import javax.microedition.khronos.opengles.GL10;
import java.util.Locale;
public class ShatteredPixelDungeon extends Game { public class ShatteredPixelDungeon extends Game {
@@ -339,6 +340,16 @@ public class ShatteredPixelDungeon extends Game {
return Preferences.INSTANCE.getInt( Preferences.KEY_BRIGHTNESS, 0 ); return Preferences.INSTANCE.getInt( Preferences.KEY_BRIGHTNESS, 0 );
} }
public static void language(Messages.Languages lang) {
Preferences.INSTANCE.put( Preferences.KEY_LANG, lang.code());
}
public static Messages.Languages language() {
String code = Preferences.INSTANCE.getString(Preferences.KEY_LANG, null);
if (code == null) return Messages.Languages.matchLocale(Locale.getDefault());
else return Messages.Languages.matchCode(code);
}
public static void lastClass( int value ) { public static void lastClass( int value ) {
Preferences.INSTANCE.put( Preferences.KEY_LAST_CLASS, value ); Preferences.INSTANCE.put( Preferences.KEY_LAST_CLASS, value );
} }
@@ -20,6 +20,8 @@
*/ */
package com.shatteredpixel.shatteredpixeldungeon.messages; package com.shatteredpixel.shatteredpixeldungeon.messages;
import com.shatteredpixel.shatteredpixeldungeon.ShatteredPixelDungeon;
import java.util.Arrays; import java.util.Arrays;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.HashMap; import java.util.HashMap;
@@ -37,7 +39,7 @@ import java.util.ResourceBundle;
public class Messages { public class Messages {
public enum Languages { public enum Languages {
ENGLISH("english", "en", Status.REVIEWED), ENGLISH("english", "", Status.REVIEWED),
RUSSIAN("русский", "ru", Status.UNREVIEWED), RUSSIAN("русский", "ru", Status.UNREVIEWED),
CHINESE("中文", "zh", Status.UNREVIEWED), //Simplified CHINESE("中文", "zh", Status.UNREVIEWED), //Simplified
@@ -45,10 +47,9 @@ public class Messages {
KOREAN("한국어", "ko", Status.UNREVIEWED), KOREAN("한국어", "ko", Status.UNREVIEWED),
GERMAN("deutsch", "de", Status.INCOMPLETE), GERMAN("deutsch", "de", Status.INCOMPLETE),
POLISH("polski", "pl", Status.INCOMPLETE),
POLISH("polski", "pl", Status.UNFINISHED), SPANISH("español", "es", Status.INCOMPLETE),
SPANISH("español", "es", Status.UNFINISHED), FRENCH("français", "fr", Status.INCOMPLETE);
FRENCH("français", "fr", Status.UNFINISHED);
private String name; private String name;
private String code; private String code;
@@ -73,7 +74,10 @@ public class Messages {
} }
public static Languages matchLocale(Locale locale){ public static Languages matchLocale(Locale locale){
String code = locale.getLanguage(); return matchCode(locale.getLanguage());
}
public static Languages matchCode(String code){
for (Languages lang : Languages.values()){ for (Languages lang : Languages.values()){
if (lang.code().equals(code)) if (lang.code().equals(code))
return lang; return lang;
@@ -82,9 +86,8 @@ public class Messages {
} }
public enum Status{ public enum Status{
//below 50% complete languages are not added. //below 60% complete languages are not added.
UNFINISHED, //50-80% complete INCOMPLETE, //60-99% complete
INCOMPLETE, //80-99% complete
UNREVIEWED, //100% complete UNREVIEWED, //100% complete
REVIEWED //100% reviewed REVIEWED //100% reviewed
} }
@@ -124,8 +127,7 @@ public class Messages {
}; };
static{ static{
//TODO:load in locale from a preference, use default only if none set. setup(ShatteredPixelDungeon.language());
setup(Languages.matchLocale(Locale.getDefault()));
} }
public static void setup( Languages lang ){ public static void setup( Languages lang ){
@@ -24,12 +24,16 @@ import com.shatteredpixel.shatteredpixeldungeon.Assets;
import com.shatteredpixel.shatteredpixeldungeon.ShatteredPixelDungeon; import com.shatteredpixel.shatteredpixeldungeon.ShatteredPixelDungeon;
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages; import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
import com.shatteredpixel.shatteredpixeldungeon.scenes.TitleScene; import com.shatteredpixel.shatteredpixeldungeon.scenes.TitleScene;
import com.shatteredpixel.shatteredpixeldungeon.windows.WndOptions;
import com.watabou.noosa.Image; import com.watabou.noosa.Image;
import com.watabou.noosa.RenderedText; import com.watabou.noosa.RenderedText;
import com.watabou.noosa.audio.Sample; import com.watabou.noosa.audio.Sample;
import com.watabou.noosa.ui.Button; import com.watabou.noosa.ui.Button;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Locale;
public class LanguageButton extends Button { public class LanguageButton extends Button {
private Image image; private Image image;
@@ -52,14 +56,11 @@ public class LanguageButton extends Button {
private void updateIcon(){ private void updateIcon(){
switch(Messages.lang().status()){ switch(Messages.lang().status()){
case UNFINISHED:
image.tint(1, 0, 0, .4f);
break;
case INCOMPLETE: case INCOMPLETE:
image.tint(1, .5f, 0, .4f); image.tint(1, 0, 0, .5f);
break; break;
case UNREVIEWED: case UNREVIEWED:
image.tint(1, 0.5f, 0, .25f); image.tint(1, .5f, 0, .5f);
break; break;
} }
} }
@@ -86,27 +87,58 @@ public class LanguageButton extends Button {
@Override @Override
protected void onClick() { protected void onClick() {
final Messages.Languages[] langs = Messages.Languages.values(); final ArrayList<Messages.Languages> langs = new ArrayList<>(Arrays.asList(Messages.Languages.values()));
final String[] names = new String[langs.length];
for (int i = 0; i < names.length; i++){ Messages.Languages nativeLang = Messages.Languages.matchLocale(Locale.getDefault());
names[i] = Messages.titleCase(langs[i].nativeName()); langs.remove(nativeLang);
switch(langs[i].status()){ //move the native language to the top.
case UNFINISHED: langs.add(0, nativeLang);
names[i] += " - UNFINISHED";
break; parent.add(new WndLangs(langs));
case INCOMPLETE: }
names[i] += " - INCOMPLETE";
break; public static class WndLangs extends Window{
private int WIDTH = 60;
private int BTN_HEIGHT = 14;
WndLangs(final List<Messages.Languages> langs){
super();
int y = 0;
for (int i = 0; i < langs.size(); i++){
final int langIndex = i;
RedButton btn = new RedButton(Messages.titleCase(langs.get(i).nativeName())){
@Override
protected void onClick() {
super.onClick();
Messages.setup(langs.get(langIndex));
ShatteredPixelDungeon.language(langs.get(langIndex));
RenderedText.clearCache();
ShatteredPixelDungeon.switchNoFade(TitleScene.class);
}
};
if (ShatteredPixelDungeon.language() == langs.get(i)){
btn.textColor(TITLE_COLOR);
} else {
switch (langs.get(i).status()) {
case INCOMPLETE:
btn.textColor(0x999999);
break;
case UNREVIEWED:
btn.textColor(0xCCCCCC);
break;
}
}
btn.setSize(WIDTH, BTN_HEIGHT);
btn.setPos(0, y);
add(btn);
y += 16;
} }
resize(WIDTH, y-2);
} }
parent.add( new WndOptions("Languages", "Select a language(proper menu soon)", names ) {
@Override
protected void onSelect(int index) {
Messages.setup(langs[index]);
updateIcon();
ShatteredPixelDungeon.switchNoFade(TitleScene.class);
RenderedText.clearCache();
}
});
} }
} }