Еще один вопрос по поводу моей реализации. Я довольно новичок в Java / Android из C / C ++ фона. Я уже реализовал это в своем коде, у меня просто есть пара проблем с ним, и я также задавался вопросом, было ли это лучшим решением и есть ли у кого-нибудь какие-либо предложения или они могли бы помочь мне с моей проблемой. Вот проблема и мои вопросы:
Мое приложение для Android должно иметь
возможности загрузки настроек
из XML-файла и приложения
необходимо разрешить пользователю изменять
эти настройки и помните
изменил настройки. Мне тоже нужен мой
приложение для ссылки на эти изменения
и определить, когда пользователь изменился
одна из настроек.
В настоящее время у меня работает вышеуказанное, за исключением того, что я хочу, чтобы настройки по умолчанию загружались из моего файла XML вместо метода, используемого в моем коде (посмотрите код, чтобы понять, о чем я говорю). Я искал вокруг этого и не могу найти решение.
Как только изменение обнаружено, мне нужно
загрузить значение в мой класс DataRobot
переменные. У меня есть функции доступа
для этого (см. код). Тем не менее, когда я
попытаться изменить любой из параметров
это не меняет значение в моем
Класс DataRobot.
Эти две цитаты из блоков объясняют, что мне нужно, в основном. Я использую настройки Android для решения этой проблемы в настоящее время. Это лучший способ решить эту проблему?
Если вам нужна дополнительная информация, пожалуйста, дайте мне знать. Спасибо за вашу помощь заранее, это очень ценится!
Кроме того, в настоящее время я испытываю несколько ошибок при текущей настройке. Ниже приводится объяснение того, когда происходит ошибка, и журнал регистрации этой ошибки.
Вывод log cat ниже происходит при первом запуске приложения. Похоже, что он имеет проблемы с преобразованием строки и выбросил ClassCastException. Я не уверен, где или почему это происходит. Весь код находится внизу поста.
02-03 20:05:50.731: INFO/System.out(279): debugger has settled (1384)
02-03 20:05:52.080: INFO/ActivityManager(59): Displayed activity com.android.launcher/com.android.launcher2.Launcher: 38755 ms (total 38755 ms)
02-03 20:05:52.480: WARN/Resources(279): Converting to string: TypedValue{t=0x10/d=0x3c a=-1}
02-03 20:05:52.669: WARN/System.err(279): java.lang.ClassCastException: java.lang.String
02-03 20:05:52.689: WARN/System.err(279): at android.app.ContextImpl$SharedPreferencesImpl.getInt(ContextImpl.java:2706)
02-03 20:05:52.689: WARN/System.err(279): at cpe495.smartapp.SmartApp.onCreate(SmartApp.java:61)
02-03 20:05:52.701: WARN/System.err(279): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-03 20:05:52.715: WARN/System.err(279): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
02-03 20:05:52.720: WARN/System.err(279): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
02-03 20:05:52.729: WARN/System.err(279): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
02-03 20:05:52.729: WARN/System.err(279): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
02-03 20:05:52.750: WARN/System.err(279): at android.os.Handler.dispatchMessage(Handler.java:99)
02-03 20:05:52.750: WARN/System.err(279): at android.os.Looper.loop(Looper.java:123)
02-03 20:05:52.760: WARN/System.err(279): at android.app.ActivityThread.main(ActivityThread.java:4627)
02-03 20:05:52.771: WARN/System.err(279): at java.lang.reflect.Method.invokeNative(Native Method)
02-03 20:05:52.781: WARN/System.err(279): at java.lang.reflect.Method.invoke(Method.java:521)
02-03 20:05:52.781: WARN/System.err(279): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
02-03 20:05:52.799: WARN/System.err(279): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
02-03 20:05:52.799: WARN/System.err(279): at dalvik.system.NativeStart.main(Native Method)
02-03 20:05:57.439: DEBUG/KeyguardViewMediator(59): pokeWakelock(5000)
02-03 20:05:57.630: DEBUG/KeyguardViewMediator(59): pokeWakelock(5000)
02-03 20:05:57.759: INFO/ActivityManager(59): Displayed activity cpe495.smartapp/.SmartApp: 10694 ms (total 10694 ms)
02-03 20:05:57.940: INFO/ARMAssembler(59): generated scanline__00000077:03545404_00000004_00000000 [ 47 ipp] (67 ins) at [0x2bd108:0x2bd214] in 2142171 ns
02-03 20:05:58.029: INFO/ARMAssembler(59): generated scanline__00000177:03515104_00001001_00000000 [ 91 ipp] (114 ins) at [0x2bd218:0x2bd3e0] in 1052927 ns
Приведенный ниже журнал cat выводится на печать после того, как пользователь использует меню настроек для изменения значения HeartRateBase в настройках. Похоже, что это происходит внутри функции onpreferenceschange.
02-03 20:06:19.000: VERBOSE/onsharedpreferencechanged(279): inside
02-03 20:06:19.009: WARN/System.err(279): java.lang.ClassCastException: java.lang.String
02-03 20:06:19.019: WARN/System.err(279): at android.app.ContextImpl$SharedPreferencesImpl.getInt(ContextImpl.java:2706)
02-03 20:06:19.031: WARN/System.err(279): at cpe495.smartapp.SmartApp.onSharedPreferenceChanged(SmartApp.java:131)
02-03 20:06:19.040: WARN/System.err(279): at android.app.ContextImpl$SharedPreferencesImpl$EditorImpl.commit(ContextImpl.java:2830)
02-03 20:06:19.040: WARN/System.err(279): at android.preference.Preference.tryCommit(Preference.java:1198)
02-03 20:06:19.050: WARN/System.err(279): at android.preference.Preference.persistString(Preference.java:1225)
02-03 20:06:19.060: WARN/System.err(279): at android.preference.ListPreference.setValue(ListPreference.java:126)
02-03 20:06:19.070: WARN/System.err(279): at android.preference.ListPreference.onDialogClosed(ListPreference.java:220)
02-03 20:06:19.120: WARN/System.err(279): at android.preference.DialogPreference.onDismiss(DialogPreference.java:384)
02-03 20:06:19.139: WARN/System.err(279): at android.app.Dialog$ListenersHandler.handleMessage(Dialog.java:1047)
02-03 20:06:19.149: WARN/System.err(279): at android.os.Handler.dispatchMessage(Handler.java:99)
02-03 20:06:19.149: WARN/System.err(279): at android.os.Looper.loop(Looper.java:123)
02-03 20:06:19.170: WARN/System.err(279): at android.app.ActivityThread.main(ActivityThread.java:4627)
02-03 20:06:19.170: WARN/System.err(279): at java.lang.reflect.Method.invokeNative(Native Method)
02-03 20:06:19.180: WARN/System.err(279): at java.lang.reflect.Method.invoke(Method.java:521)
02-03 20:06:19.190: WARN/System.err(279): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
02-03 20:06:19.200: WARN/System.err(279): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
02-03 20:06:19.200: WARN/System.err(279): at dalvik.system.NativeStart.main(Native Method)
02-03 20:06:19.320: WARN/InputManagerService(59): Window already focused, ignoring focus gain of: com.android.internal.view.IInputMethodClient$Stub$Proxy@43e60f18
Здесь начинается код, который у меня есть для этих проблем.
//The Main Class, mainly my gui class
public class SmartApp extends Activity implements OnSharedPreferenceChangeListener {
private DataRobot dR = new DataRobot();
public SmartApp() {}
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.intro);
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
PreferenceManager.setDefaultValues(this, R.xml.settings, false);
prefs.registerOnSharedPreferenceChangeListener(this);
//set remembered preferences
try {
dR.sethRB(prefs.getInt("heartRateBaseKey", 60));
dR.sethRVMax(prefs.getInt("hRVMaxKey", 100));
dR.sethRVMin(prefs.getInt("hRVMinKey", 0));
dR.setsI1(prefs.getInt("sI1Key", 50));
dR.setsI2(prefs.getInt("sI2Key", 80));
dR.setW1(prefs.getInt("weight1Key", 20));
dR.setW2(prefs.getInt("weight2Key", 40));
dR.setW3(prefs.getInt("weight3Key", 60));
}
catch (ClassCastException e) {
e.printStackTrace();
}
final Button smartConnectionSettingsButton = (Button) findViewById(R.id.smartConnectionSettingsButton);
smartConnectionSettingsButton.setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Intent settingsIntent = new Intent(v.getContext(), Settings.class);
startActivityForResult(settingsIntent, 0);
}
});
}
@Override
public void onSharedPreferenceChanged(SharedPreferences prefs,
String key) {
// TODO Auto-generated method stub
Log.v("onsharedpreferencechanged", "inside");
try {
if(key.equals("heartRateBaseKey")) {
dR.sethRB(prefs.getInt("heartRateBaseKey", 60));
}
else if(key.equals("hRVMaxKey")) {
dR.sethRVMax(prefs.getInt("hRVMaxKey", 100));
}
else if(key.equals("hRVMinKey")) {
dR.sethRVMin(prefs.getInt("hRVMinKey", 0));
}
else if(key.equals("sI1Key")) {
dR.setsI1(prefs.getInt("sI1Key", 50));
}
else if(key.equals("sI2Key")) {
dR.setsI2(prefs.getInt("sI2Key", 80));
}
else if(key.equals("weight1Key")) {
dR.setW1(prefs.getInt("weight1Key", 20));
}
else if(key.equals("weight2Key")) {
dR.setW2(prefs.getInt("weight2Key", 40));
}
else if(key.equals("weight3Key")) {
dR.setW3(prefs.getInt("weight3Key", 60));
}
}
catch (ClassCastException e) {
e.printStackTrace();
}
}
}
Этот класс - то, где я анализирую данные, и мне нужно, чтобы рядовые значения были установлены во время запуска приложения. В настоящее время я делаю это в методе onCreate в SmartApp. Мне также нужно, чтобы значения изменялись в режиме реального времени, если пользователь изменяет какие-либо настройки во время выполнения.
public class DataRobot {
/* This class is for analyzing the data */
private SmartDataObject data;
private int sI1;
private int sI2;
private int w1;
private int w2;
private int w3;
private int hRB;
private int hRVMin;
private int hRVMax;
public boolean analyzeData(SmartDataObject temp) {}
public void setsI1(int temp) {
sI1 = temp;
}
public void setsI2(int temp) {
sI2 = temp;
}
public void setW1(int temp) {
w1 = temp;
}
public void setW2(int temp) {
w2 = temp;
}
public void setW3(int temp) {
w3 = temp;
}
public void sethRB(int temp) {
hRB = temp;
}
public void sethRVMin(int temp) {
hRVMin = temp;
}
public void sethRVMax(int temp) {
hRVMax = temp;
}
}
Ниже приведен класс предпочтений
import android.os.Bundle;
import android.preference.PreferenceActivity;
public class Preferences extends PreferenceActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.settings);
}
}
Ниже приведен файл XML для моих предпочтений с именем «settings.xml».
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen
xmlns:android="http://schemas.android.com/apk/res/android">
<PreferenceCategory android:title="Profile Settings">
<EditTextPreference
android:title="First Name"
android:key="firstNameKey"
android:selectable="false"></EditTextPreference>
<EditTextPreference
android:title="Last Name"
android:key="lastNameKey"
android:selectable="false"></EditTextPreference>
<EditTextPreference
android:title="User Name"
android:key="userNameKey"
android:selectable="false"></EditTextPreference>
<EditTextPreference
android:title="Birth Date"
android:key="birthDateKey"
android:selectable="false"></EditTextPreference>
</PreferenceCategory>
<PreferenceCategory
android:title="Configuration Settings">
<ListPreference
android:title="Medium Stress Index Threshold"
android:entryValues="@array/sI1Values"
android:entries="@array/sI1Array"
android:key="sI1Key"></ListPreference>
<ListPreference
android:title="High Stress Index Threshold"
android:entryValues="@array/sI1Values"
android:entries="@array/sI1Array"
android:key="sI2Key"></ListPreference>
<EditTextPreference
android:title="Weight 1"
android:key="weight1Key"></EditTextPreference>
<EditTextPreference
android:title="Weight 2"
android:key="weight2Key"></EditTextPreference>
<EditTextPreference
android:title="Weight 3"
android:key="weight3Key"></EditTextPreference>
<ListPreference
android:entryValues="@array/heartRateBaseValues"
android:entries="@array/heartRateBaseArray"
android:defaultValue="60"
android:key="heartRateBaseKey"
android:title="Heart Rate Base"></ListPreference>
<EditTextPreference
android:title="Heart Rate Variability Minimum"
android:key="hRVMinKey"></EditTextPreference>
<EditTextPreference
android:title="Heart Rate Variability Maximum"
android:key="hRVMaxKey"></EditTextPreference>
</PreferenceCategory>
</PreferenceScreen>
Ниже приведен файл "arrayValues.xml", который содержит некоторые значения для некоторых вещей.
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="heartRateBaseArray">
<item>10 bpm</item>
<item>20 bpm</item>
<item>30 bpm</item>
<item>40 bpm</item>
<item>50 bpm</item>
<item>60 bpm</item>
<item>70 bpm</item>
<item>80 bpm</item>
<item>90 bpm</item>
<item>100 bpm</item>
</string-array>
<string-array name="heartRateBaseValues">
<item>10</item>
<item>20</item>
<item>30</item>
<item>40</item>
<item>50</item>
<item>60</item>
<item>70</item>
<item>80</item>
<item>90</item>
<item>100</item>
</string-array>
<string-array name="sI1Array">
<item>0</item>
<item>5</item>
<item>10</item>
<item>15</item>
<item>20</item>
<item>25</item>
<item>30</item>
<item>35</item>
<item>40</item>
<item>45</item>
<item>50</item>
<item>55</item>
<item>60</item>
<item>65</item>
<item>70</item>
<item>75</item>
<item>80</item>
<item>85</item>
<item>90</item>
<item>95</item>
<item>100</item>
</string-array>
<string-array name="sI1Values">
<item>0</item>
<item>5</item>
<item>10</item>
<item>15</item>
<item>20</item>
<item>25</item>
<item>30</item>
<item>35</item>
<item>40</item>
<item>45</item>
<item>50</item>
<item>55</item>
<item>60</item>
<item>65</item>
<item>70</item>
<item>75</item>
<item>80</item>
<item>85</item>
<item>90</item>
<item>95</item>
<item>100</item>
</string-array>
</resources>