v0.3.4: more language button work
This commit is contained in:
committed by
Evan Debenham
parent
e27c0fba11
commit
31a8e50754
@@ -20,9 +20,8 @@
|
||||
*/
|
||||
package com.shatteredpixel.shatteredpixeldungeon;
|
||||
|
||||
import com.watabou.noosa.Game;
|
||||
|
||||
import android.content.SharedPreferences;
|
||||
import com.watabou.noosa.Game;
|
||||
|
||||
enum Preferences {
|
||||
|
||||
@@ -42,6 +41,7 @@ enum Preferences {
|
||||
public static final String KEY_FLIPTOOLBAR = "flipped_ui";
|
||||
public static final String KEY_FLIPTAGS = "flip_tags";
|
||||
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_BRIGHTNESS = "brightness";
|
||||
public static final String KEY_VERSION = "version";
|
||||
|
||||
@@ -20,21 +20,22 @@
|
||||
*/
|
||||
package com.shatteredpixel.shatteredpixeldungeon;
|
||||
|
||||
import javax.microedition.khronos.opengles.GL10;
|
||||
|
||||
import android.annotation.SuppressLint;
|
||||
import android.content.pm.ActivityInfo;
|
||||
import android.os.Bundle;
|
||||
import android.util.DisplayMetrics;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
|
||||
import com.watabou.noosa.Game;
|
||||
import com.watabou.noosa.audio.Music;
|
||||
import com.watabou.noosa.audio.Sample;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.PixelScene;
|
||||
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 {
|
||||
|
||||
@@ -339,6 +340,16 @@ public class ShatteredPixelDungeon extends Game {
|
||||
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 ) {
|
||||
Preferences.INSTANCE.put( Preferences.KEY_LAST_CLASS, value );
|
||||
}
|
||||
|
||||
@@ -20,6 +20,8 @@
|
||||
*/
|
||||
package com.shatteredpixel.shatteredpixeldungeon.messages;
|
||||
|
||||
import com.shatteredpixel.shatteredpixeldungeon.ShatteredPixelDungeon;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Enumeration;
|
||||
import java.util.HashMap;
|
||||
@@ -37,7 +39,7 @@ import java.util.ResourceBundle;
|
||||
public class Messages {
|
||||
|
||||
public enum Languages {
|
||||
ENGLISH("english", "en", Status.REVIEWED),
|
||||
ENGLISH("english", "", Status.REVIEWED),
|
||||
|
||||
RUSSIAN("русский", "ru", Status.UNREVIEWED),
|
||||
CHINESE("中文", "zh", Status.UNREVIEWED), //Simplified
|
||||
@@ -45,10 +47,9 @@ public class Messages {
|
||||
KOREAN("한국어", "ko", Status.UNREVIEWED),
|
||||
|
||||
GERMAN("deutsch", "de", Status.INCOMPLETE),
|
||||
|
||||
POLISH("polski", "pl", Status.UNFINISHED),
|
||||
SPANISH("español", "es", Status.UNFINISHED),
|
||||
FRENCH("français", "fr", Status.UNFINISHED);
|
||||
POLISH("polski", "pl", Status.INCOMPLETE),
|
||||
SPANISH("español", "es", Status.INCOMPLETE),
|
||||
FRENCH("français", "fr", Status.INCOMPLETE);
|
||||
|
||||
private String name;
|
||||
private String code;
|
||||
@@ -73,7 +74,10 @@ public class Messages {
|
||||
}
|
||||
|
||||
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()){
|
||||
if (lang.code().equals(code))
|
||||
return lang;
|
||||
@@ -82,9 +86,8 @@ public class Messages {
|
||||
}
|
||||
|
||||
public enum Status{
|
||||
//below 50% complete languages are not added.
|
||||
UNFINISHED, //50-80% complete
|
||||
INCOMPLETE, //80-99% complete
|
||||
//below 60% complete languages are not added.
|
||||
INCOMPLETE, //60-99% complete
|
||||
UNREVIEWED, //100% complete
|
||||
REVIEWED //100% reviewed
|
||||
}
|
||||
@@ -124,8 +127,7 @@ public class Messages {
|
||||
};
|
||||
|
||||
static{
|
||||
//TODO:load in locale from a preference, use default only if none set.
|
||||
setup(Languages.matchLocale(Locale.getDefault()));
|
||||
setup(ShatteredPixelDungeon.language());
|
||||
}
|
||||
|
||||
public static void setup( Languages lang ){
|
||||
|
||||
@@ -24,12 +24,16 @@ import com.shatteredpixel.shatteredpixeldungeon.Assets;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.ShatteredPixelDungeon;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.TitleScene;
|
||||
import com.shatteredpixel.shatteredpixeldungeon.windows.WndOptions;
|
||||
import com.watabou.noosa.Image;
|
||||
import com.watabou.noosa.RenderedText;
|
||||
import com.watabou.noosa.audio.Sample;
|
||||
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 {
|
||||
|
||||
private Image image;
|
||||
@@ -52,14 +56,11 @@ public class LanguageButton extends Button {
|
||||
|
||||
private void updateIcon(){
|
||||
switch(Messages.lang().status()){
|
||||
case UNFINISHED:
|
||||
image.tint(1, 0, 0, .4f);
|
||||
break;
|
||||
case INCOMPLETE:
|
||||
image.tint(1, .5f, 0, .4f);
|
||||
image.tint(1, 0, 0, .5f);
|
||||
break;
|
||||
case UNREVIEWED:
|
||||
image.tint(1, 0.5f, 0, .25f);
|
||||
image.tint(1, .5f, 0, .5f);
|
||||
break;
|
||||
}
|
||||
}
|
||||
@@ -86,27 +87,58 @@ public class LanguageButton extends Button {
|
||||
|
||||
@Override
|
||||
protected void onClick() {
|
||||
final Messages.Languages[] langs = Messages.Languages.values();
|
||||
final String[] names = new String[langs.length];
|
||||
for (int i = 0; i < names.length; i++){
|
||||
names[i] = Messages.titleCase(langs[i].nativeName());
|
||||
switch(langs[i].status()){
|
||||
case UNFINISHED:
|
||||
names[i] += " - UNFINISHED";
|
||||
break;
|
||||
case INCOMPLETE:
|
||||
names[i] += " - INCOMPLETE";
|
||||
break;
|
||||
final ArrayList<Messages.Languages> langs = new ArrayList<>(Arrays.asList(Messages.Languages.values()));
|
||||
|
||||
Messages.Languages nativeLang = Messages.Languages.matchLocale(Locale.getDefault());
|
||||
langs.remove(nativeLang);
|
||||
//move the native language to the top.
|
||||
langs.add(0, nativeLang);
|
||||
|
||||
parent.add(new WndLangs(langs));
|
||||
}
|
||||
|
||||
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();
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user