何らかの理由で、このコードは をスローしておりClassCastException
、Double を Float にキャストできないことを示しています。例外は、以下のコードの最初の行から発生します。mapData.speeds
ですArrayList<Float>
。ダブルはどこ?
float spd = mapData.speeds.get(focusPointIndex);
spd = (spd * 3600/1609.34);
完全なスタック トレースは次のとおりです。
03-31 01:00:51.008: E/AndroidRuntime(17778): FATAL EXCEPTION: main
03-31 01:00:51.008: E/AndroidRuntime(17778): java.lang.ClassCastException: java.lang.Double cannot be cast to java.lang.Float
03-31 01:00:51.008: E/AndroidRuntime(17778): at net.taptools.android.trailtracker.ResultsMapViewingFragment$4.onMapLongClick(ResultsMapViewingFragment.java:224)
03-31 01:00:51.008: E/AndroidRuntime(17778): at com.google.android.gms.maps.GoogleMap$5.onMapLongClick(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at com.google.android.gms.internal.k$a.onTransact(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at android.os.Binder.transact(Binder.java:326)
03-31 01:00:51.008: E/AndroidRuntime(17778): at com.google.android.gms.maps.internal.IOnMapLongClickListener$Stub$Proxy.onMapLongClick(IOnMapLongClickListener.java:93)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.i.s.a(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.y.v.d(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.y.bf.onLongPress(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.d.v.onLongPress(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.d.h.c(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.d.h.c(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at maps.d.j.handleMessage(Unknown Source)
03-31 01:00:51.008: E/AndroidRuntime(17778): at android.os.Handler.dispatchMessage(Handler.java:99)
03-31 01:00:51.008: E/AndroidRuntime(17778): at android.os.Looper.loop(Looper.java:137)
03-31 01:00:51.008: E/AndroidRuntime(17778): at android.app.ActivityThread.main(ActivityThread.java:5059)
03-31 01:00:51.008: E/AndroidRuntime(17778): at java.lang.reflect.Method.invokeNative(Native Method)
03-31 01:00:51.008: E/AndroidRuntime(17778): at java.lang.reflect.Method.invoke(Method.java:511)
03-31 01:00:51.008: E/AndroidRuntime(17778): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
03-31 01:00:51.008: E/AndroidRuntime(17778): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555)
03-31 01:00:51.008: E/AndroidRuntime(17778): at dalvik.system.NativeStart.main(Native Method)
- 編集 -
エラーの原因はわかったと思いますが、エラーが発生する理由や修正方法はまだわかりません。JSON から mapData オブジェクトを解析しています。さまざまな型の ArrayList が多数含まれているため、JSONArray を解析して指定された型の ArrayList にするメソッドを作成しました。これが方法です。
private <T> ArrayList<T> JSONArrayToList(JSONArray jsonArr){
ArrayList<T> arrList = new ArrayList<T>();
for(int i = 0; i<jsonArr.length(); i++){
try {
arrList.add((T)jsonArr.get(i));
} catch (JSONException e){e.printStackTrace();}
}
return arrList;
}