Проблемы с настройками Android и необходимая помощь - PullRequest
1 голос
/ 04 февраля 2011

Еще один вопрос по поводу моей реализации. Я довольно новичок в 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>   

Ответы [ 2 ]

1 голос
/ 04 февраля 2011

Из-за вашей ошибки у меня была похожая проблема с моими приложениями, и я обошел это путем извлечения предпочтений в виде объектов String, а затем с помощью Integer.parse() преобразовал String в число.Это что-то вроде хака, но это сделало всю работу за меня.

Что касается вашего первоначального вопроса, можете ли вы сделать так, чтобы ваша PreferenceActivity записывала в определенный конкретный файл, когда внесено изменение, которое другая активность может периодически проверятьили на его создание и корректировку / извлечение информации соответственно?

1 голос
/ 04 февраля 2011

Не углубляясь в ваш код.Я бы начал с просмотра строк 61 и 131 в вашем коде SmartApp.Это где исключение начинается в обоих случаях.Если в обоих случаях это указывает на вызов с использованием prefs.getInt(), я предполагаю, что это как-то связано с тем, что вы запрашиваете int, хотя на самом деле исходные записи XML являются строками.

...