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;
|
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();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user