{ "id": "98112", "key": "TIMOB-10171", "fields": { "issuetype": { "id": "1", "description": "A problem which impairs or prevents the functions of the product.", "name": "Bug", "subtask": false }, "project": { "id": "10153", "key": "TIMOB", "name": "Titanium SDK/CLI", "projectCategory": { "id": "10100", "description": "Titanium and related SDKs used in application development", "name": "Client" } }, "fixVersions": [ { "id": "13505", "description": "Release 3.0.0", "name": "Release 3.0.0", "archived": true, "released": true, "releaseDate": "2012-12-14" }, { "id": "14098", "description": "Sprint 2012-18 API", "name": "Sprint 2012-18 API", "archived": true, "released": true, "releaseDate": "2012-09-10" }, { "id": "14275", "description": "2012 Sprint 18", "name": "2012 Sprint 18", "archived": true, "released": true, "releaseDate": "2012-09-10" }, { "id": "14168", "description": "2012 Sprint 22 API", "name": "2012 Sprint 22 API", "archived": true, "released": true, "releaseDate": "2012-11-05" }, { "id": "14274", "description": "2012 Sprint 22", "name": "2012 Sprint 22", "archived": true, "released": true, "releaseDate": "2012-11-05" } ], "resolution": { "id": "1", "description": "A fix for this issue is checked into the tree and tested.", "name": "Fixed" }, "resolutiondate": "2012-10-30T00:22:21.000+0000", "created": "2012-07-26T13:29:36.000+0000", "priority": { "name": "High", "id": "2" }, "labels": [ "api", "community", "module_map", "qe-and100112", "qe-review", "qe-testadded" ], "versions": [ { "id": "13271", "description": "Release 2.1.0", "name": "Release 2.1.0", "archived": false, "released": true, "releaseDate": "2012-06-29" } ], "issuelinks": [], "assignee": { "name": "hpham", "key": "hpham", "displayName": "Hieu Pham", "active": true, "timeZone": "America/Los_Angeles" }, "updated": "2012-11-12T18:46:45.000+0000", "status": { "description": "The issue is considered finished, the resolution is correct. Issues which are closed can be reopened.", "name": "Closed", "id": "6", "statusCategory": { "id": 3, "key": "done", "colorName": "green", "name": "Done" } }, "components": [ { "id": "10202", "name": "Android", "description": "Android Platform" } ], "description": "I am tracking a user running and updating a map with a route. After a certain amount of points are added to the route I get the below error: \r\n{code}\r\nW/dalvikvm(12413): threadid=1: thread exiting with uncaught exception (group=0x4001d560)\r\nE/TiApplication(12413): (main) [169428,177873] Sending event: exception on thread: main msg:java.util.ConcurrentModificationException; Titanium 2.1.0,2012/06/28 12:16,6e3cab6\r\nE/TiApplication(12413): java.util.ConcurrentModificationException\r\nE/TiApplication(12413): at java.util.ArrayList$ArrayListIterator.next(ArrayList.java:576)\r\nE/TiApplication(12413): at com.google.android.maps.OverlayBundle.draw(OverlayBundle.java:41)\r\nE/TiApplication(12413): at com.google.android.maps.MapView.onDraw(MapView.java:530)\r\nE/TiApplication(12413): at android.view.View.draw(View.java:6902)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at org.appcelerator.titanium.view.TiCompositeLayout.dispatchDraw(TiCompositeLayout.java:655)\r\nE/TiApplication(12413): at android.view.View.draw(View.java:6905)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at org.appcelerator.titanium.view.TiCompositeLayout.dispatchDraw(TiCompositeLayout.java:655)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.View.draw(View.java:6905)\r\nE/TiApplication(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/TiApplication(12413): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1957)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.View.draw(View.java:6905)\r\nE/TiApplication(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at org.appcelerator.titanium.view.TiCompositeLayout.dispatchDraw(TiCompositeLayout.java:655)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.View.draw(View.java:6905)\r\nE/TiApplication(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/TiApplication(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/TiApplication(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/TiApplication(12413): at android.view.View.draw(View.java:6905)\r\nE/TiApplication(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/TiApplication(12413): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1957)\r\nE/TiApplication(12413): at android.view.ViewRoot.draw(ViewRoot.java:1554)\r\nE/TiApplication(12413): at android.view.ViewRoot.performTraversals(ViewRoot.java:1263)\r\nE/TiApplication(12413): at android.view.ViewRoot.handleMessage(ViewRoot.java:1892)\r\nE/TiApplication(12413): at android.os.Handler.dispatchMessage(Handler.java:99)\r\nE/TiApplication(12413): at android.os.Looper.loop(Looper.java:130)\r\nE/TiApplication(12413): at android.app.ActivityThread.main(ActivityThread.java:3835)\r\nE/TiApplication(12413): at java.lang.reflect.Method.invokeNative(Native Method)\r\nE/TiApplication(12413): at java.lang.reflect.Method.invoke(Method.java:507)\r\nE/TiApplication(12413): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)\r\nE/TiApplication(12413): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)\r\nE/TiApplication(12413): at dalvik.system.NativeStart.main(Native Method)\r\nE/AndroidRuntime(12413): FATAL EXCEPTION: main\r\nE/AndroidRuntime(12413): java.util.ConcurrentModificationException\r\nE/AndroidRuntime(12413): at java.util.ArrayList$ArrayListIterator.next(ArrayList.java:576)\r\nE/AndroidRuntime(12413): at com.google.android.maps.OverlayBundle.draw(OverlayBundle.java:41)\r\nE/AndroidRuntime(12413): at com.google.android.maps.MapView.onDraw(MapView.java:530)\r\nE/AndroidRuntime(12413): at android.view.View.draw(View.java:6902)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at org.appcelerator.titanium.view.TiCompositeLayout.dispatchDraw(TiCompositeLayout.java:655)\r\nE/AndroidRuntime(12413): at android.view.View.draw(View.java:6905)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at org.appcelerator.titanium.view.TiCompositeLayout.dispatchDraw(TiCompositeLayout.java:655)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.View.draw(View.java:6905)\r\nE/AndroidRuntime(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/AndroidRuntime(12413): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1957)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.View.draw(View.java:6905)\r\nE/AndroidRuntime(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at org.appcelerator.titanium.view.TiCompositeLayout.dispatchDraw(TiCompositeLayout.java:655)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.View.draw(View.java:6905)\r\nE/AndroidRuntime(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)\r\nE/AndroidRuntime(12413): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)\r\nE/AndroidRuntime(12413): at android.view.View.draw(View.java:6905)\r\nE/AndroidRuntime(12413): at android.widget.FrameLayout.draw(FrameLayout.java:357)\r\nE/AndroidRuntime(12413): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1957)\r\nE/AndroidRuntime(12413): at android.view.ViewRoot.draw(ViewRoot.java:1554)\r\nE/AndroidRuntime(12413): at android.view.ViewRoot.performTraversals(ViewRoot.java:1263)\r\nE/AndroidRuntime(12413): at android.view.ViewRoot.handleMessage(ViewRoot.java:1892)\r\nE/AndroidRuntime(12413): at android.os.Handler.dispatchMessage(Handler.java:99)\r\nE/AndroidRuntime(12413): at android.os.Looper.loop(Looper.java:130)\r\nE/AndroidRuntime(12413): at android.app.ActivityThread.main(ActivityThread.java:3835)\r\nE/AndroidRuntime(12413): at java.lang.reflect.Method.invokeNative(Native Method)\r\nE/AndroidRuntime(12413): at java.lang.reflect.Method.invoke(Method.java:507)\r\nE/AndroidRuntime(12413): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)\r\nE/AndroidRuntime(12413): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)\r\nE/AndroidRuntime(12413): at dalvik.system.NativeStart.main(Native Method)\r\nW/ActivityManager( 1646): Force finishing activity com.libertastechnologies.stelizabeth/ti.modules.titanium.ui.TiTabActivity\r\n{code}\r\n\r\n\r\n\r\n1. Run this code, interact with screen, and you should be able to see this in ~5 seconds.\r\n{code}\r\nvar win = Ti.UI.createWindow({\r\n\tbackgroundColor : '#00f'\r\n});\r\n\r\nvar maproute = {\r\n\tname : 'runtrackerroute',\r\n\tpoints : [{\r\n\t\tlatitude : 42.3353,\r\n\t\tlongitude : -71.1715\r\n\t}, {\r\n\t\tlatitude : 42.3355,\r\n\t\tlongitude : -71.1725\r\n\t}, {\r\n\t\tlatitude : 42.3359,\r\n\t\tlongitude : -71.1735\r\n\t}],\r\n\tcolor : 'blue',\r\n\twidth : 4\r\n};\r\n\r\nvar map = Titanium.Map.createView({\r\n\tmapType : Titanium.Map.STANDARD_TYPE,\r\n\tregion : {\r\n\t\tlatitude : 42.3366,\r\n\t\tlongitude : -71.1689,\r\n\t\tlatitudeDelta : 0.01,\r\n\t\tlongitudeDelta : 0.01\r\n\t}\r\n});\r\nmap.addRoute(maproute);\r\n\r\nfunction UpdateMapRoute(lat, lon)\r\n{\r\n\t//remove route\r\n\tmap.removeRoute(maproute);\r\n\r\n\t//add new points\r\n\tmaproute.points.push({\r\n\t\t'latitude' : lat,\r\n\t\t'longitude' : lon\r\n\t});\r\n\r\n\t//add route\r\n\tmap.addRoute(maproute);\r\n\t\r\n\tmap.setLocation({\r\n\t\tlatitude : lat,\r\n\t\tlongitude : lon,\r\n\t\tanimate : true,\r\n\t\tlatitudeDelta : 0.001,\r\n\t\tlongitudeDelta : 0.004\r\n\t});\r\n\r\n}\r\n\r\nvar lat = 42.3359;\r\nvar lon = -71.1735;\r\n\r\nsetInterval(function(){\r\n\tUpdateMapRoute(lat,lon);\r\n\tlat = lat + .002;\r\n\tlon = lon + .002;\r\n},500);\r\n\r\n\r\n\r\nwin.add(map);\r\nwin.open();\r\n{code}\r\n", "attachment": [ { "id": "32337", "filename": "device-2012-10-05-140900.png", "author": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-10-05T21:25:58.000+0000", "size": 22777, "mimeType": "image/png" } ], "flagged": false, "summary": "Android: When dynamically adding route points to a map over time causes app to crash", "creator": { "name": "aroyce", "key": "aroyce", "displayName": "Andrew Royce", "active": true, "timeZone": "America/New_York" }, "subtasks": [], "reporter": { "name": "aroyce", "key": "aroyce", "displayName": "Andrew Royce", "active": true, "timeZone": "America/New_York" }, "environment": "Windows 7 running Titanium Studio build: 2.1.0.201206251749. Latest SDK 2.1.0.GA Rhino. Installed on HTC Thunderbolt", "comment": { "comments": [ { "id": "209731", "author": { "name": "aroyce", "key": "aroyce", "displayName": "Andrew Royce", "active": true, "timeZone": "America/New_York" }, "body": "Tried to add this under Ti-MOB but dont have that as an option when I select 'Create Issue' button.", "updateAuthor": { "name": "aroyce", "key": "aroyce", "displayName": "Andrew Royce", "active": true, "timeZone": "America/New_York" }, "created": "2012-07-26T13:30:43.000+0000", "updated": "2012-07-26T13:30:43.000+0000" }, { "id": "214536", "author": { "name": "abauer", "key": "abauer", "displayName": "Alexander Bauer", "active": true, "timeZone": "America/Los_Angeles" }, "body": "I also experience heavy performance issues when adding a real route (consists of 100+ points), this affects android only.", "updateAuthor": { "name": "abauer", "key": "abauer", "displayName": "Alexander Bauer", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-08-15T03:56:51.000+0000", "updated": "2012-08-15T03:56:51.000+0000" }, { "id": "216164", "author": { "name": "aroyce", "key": "aroyce", "displayName": "Andrew Royce", "active": true, "timeZone": "America/New_York" }, "body": "Any update on this? I'm stuck until this gets fixed. Is there anything else I can do to help speed up this development?\r\n", "updateAuthor": { "name": "aroyce", "key": "aroyce", "displayName": "Andrew Royce", "active": true, "timeZone": "America/New_York" }, "created": "2012-08-27T06:25:39.000+0000", "updated": "2012-08-27T06:25:39.000+0000" }, { "id": "216664", "author": { "name": "hpham", "key": "hpham", "displayName": "Hieu Pham", "active": true, "timeZone": "America/Los_Angeles" }, "body": "This issue is being addressed. As for performance, how are you adding routes? If you could provide a sample code (preferably in a new JIRA ticket), we'll be more than happy to dig into it.", "updateAuthor": { "name": "hpham", "key": "hpham", "displayName": "Hieu Pham", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-08-28T17:41:15.000+0000", "updated": "2012-08-28T17:41:15.000+0000" }, { "id": "216997", "author": { "name": "ayeung", "key": "ayeung", "displayName": "Allen Yeung", "active": true, "timeZone": "America/Los_Angeles" }, "body": "PR: https://github.com/appcelerator/titanium_mobile/pull/2849", "updateAuthor": { "name": "ayeung", "key": "ayeung", "displayName": "Allen Yeung", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-08-30T10:20:14.000+0000", "updated": "2012-08-30T10:20:14.000+0000" }, { "id": "217127", "author": { "name": "ssekhri", "key": "ssekhri", "displayName": "Satyam Sekhri", "active": true, "timeZone": "America/Los_Angeles" }, "body": "The app does not crash.\r\nVerified on:\r\nTitanium Studio: 2.1.2.201208301612\r\nTitanium SDK: 2.2.0.v20120830182512\r\nAndroid Device: LG-P970 (v2.2), Galaxy Note (v2.3), Galaxy Nexus (v4.0.2)\r\nAndroid Runtime: v8, Rhino", "updateAuthor": { "name": "ssekhri", "key": "ssekhri", "displayName": "Satyam Sekhri", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-08-31T03:09:08.000+0000", "updated": "2012-08-31T03:09:08.000+0000" }, { "id": "217797", "author": { "name": "sbhadauria", "key": "sbhadauria", "displayName": "Shyam Bhadauria", "active": true, "timeZone": "America/Los_Angeles" }, "body": "Re-opening to edit label", "updateAuthor": { "name": "sbhadauria", "key": "sbhadauria", "displayName": "Shyam Bhadauria", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-09-06T04:47:28.000+0000", "updated": "2012-09-06T04:47:28.000+0000" }, { "id": "222324", "author": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "body": "Reopening the bug, because the app still crashes.\r\nNeed to wait approximately 40-60 sec to see mapView turns black (screenshot is attached) and then rotate device to landscape mode.\r\nTested on:\r\nOS: Mac OS X Lion 10.7.4\r\nTitanium Studio, build: 2.1.2.201208301612\r\nTitanium SDK, build: 3.0.0.v20121005130642\r\nDevice: Samsung Galaxy III (4.0.4), Nexus 7 (4.1.1)\r\n", "updateAuthor": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-10-05T21:25:01.000+0000", "updated": "2012-10-05T21:25:01.000+0000" }, { "id": "225466", "author": { "name": "hpham", "key": "hpham", "displayName": "Hieu Pham", "active": true, "timeZone": "America/Los_Angeles" }, "updateAuthor": { "name": "hpham", "key": "hpham", "displayName": "Hieu Pham", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-10-30T00:19:40.000+0000", "updated": "2012-10-30T00:19:40.000+0000" } ], "maxResults": 9, "total": 9, "startAt": 0 } } }