{ "id": "94529", "key": "AC-2914", "fields": { "issuetype": { "id": "1", "description": "A problem which impairs or prevents the functions of the product.", "name": "Bug", "subtask": false }, "project": { "id": "12217", "key": "AC", "name": "Appcelerator - INBOX", "projectCategory": { "id": "10000", "description": "", "name": "Customer Service" } }, "resolution": { "id": "7", "description": "", "name": "Invalid" }, "resolutiondate": "2012-07-18T11:46:09.000+0000", "created": "2012-07-06T11:55:22.000+0000", "labels": [ "android", "defect", "mapview", "titanbeta" ], "versions": [], "issuelinks": [], "assignee": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "updated": "2016-03-08T07:47:53.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": "14548", "name": "Titanium SDK & CLI", "description": "Please enter tickets related to the MobileSDK here." } ], "description": "h4.Problem\r\nIf you attempt to add any view to a Map View, the added view will not appear. As Titanium.Map.View decends from Titanium.UI.View, you should be able to add any view you want to (on top of) a Map View.\r\n\r\nh4.Expected behavior\r\nA red square should appear in the bottom left corner of the map.\r\n\r\nh4.Actual behavior\r\nThe red square does not appear at all.\r\n\r\nh4.Testcase\r\nPaste the following code into a new project's app.js file and run it using the Android 2.2 Google APIs emulator.\r\n\r\nIf you change \"Ti.Map.createView\" to Ti.UI.createView\", the red square appears correctly.\r\n\r\n{panel:title=app.js}\r\n{code}\r\nvar win1 = Ti.UI.createWindow({\r\n backgroundColor:'#fff',\r\n exitOnClose:true,\r\n navBarHidden:true,\r\n layout:'vertical'\r\n});\r\n \r\nvar map1=Ti.Map.createView({\r\n mapType:Ti.Map.STANDARD_TYPE,\r\n animate:true,\r\n region:{latitude:37.423156, longitude:-122.084917,\r\n latitudeDelta:0.01, longitudeDelta:0.01},\r\n regionFit:true,\r\n annotations:[Ti.Map.createAnnotation({\r\n latitude:37.423156,\r\n longitude:-122.084917,\r\n image:'/images/MapPin.png'\r\n })],\r\n userLocation:true,\r\n height:Ti.UI.Fill\r\n });\r\nwin1.add(map1);\r\n \r\nvar square1=Ti.UI.createView({\r\n height:20,\r\n width:20,\r\n backgroundColor:'red',\r\n bottom:10,\r\n left:10\r\n });\r\nmap1.add(square1);\r\n \r\nwin1.open();\r\n{code}\r\n{panel}\r\n\r\nh4. Solution/Fix\r\n\r\n{panel:title=app.js}\r\n{code}\r\nvar win1 = Ti.UI.createWindow({\r\n\tbackgroundColor : '#fff',\r\n\texitOnClose : true,\r\n\tnavBarHidden : true,\r\n\t//layout : 'vertical'\r\n});\r\n\r\nvar map1 = Ti.Map.createView({\r\n\tmapType : Ti.Map.STANDARD_TYPE,\r\n\tanimate : true,\r\n\tregion : {\r\n\t\tlatitude : 37.423156,\r\n\t\tlongitude : -122.084917,\r\n\t\tlatitudeDelta : 0.01,\r\n\t\tlongitudeDelta : 0.01\r\n\t},\r\n\tregionFit : true,\r\n\tannotations : [Ti.Map.createAnnotation({\r\n\t\tlatitude : 37.423156,\r\n\t\tlongitude : -122.084917,\r\n\t\timage : '/images/MapPin.png'\r\n\t})],\r\n\tuserLocation : true,\r\n\theight : Ti.UI.Fill\r\n});\r\nwin1.add(map1);\r\n\r\nvar square1 = Ti.UI.createView({\r\n\theight : 20,\r\n\twidth : 20,\r\n\tbackgroundColor : 'red',\r\n\tbottom : 10,\r\n\tleft : 10,\r\n\t//zIndex: 1\r\n});\r\nwin1.add(square1);\r\n\r\nwin1.open(); \r\n{code}\r\n{panel}\r\n\r\nh4. View Based Solution\r\n{panel:title=app.js}\r\n{code}\r\nvar win1 = Ti.UI.createWindow({\r\n\tbackgroundColor : '#fff',\r\n\texitOnClose : true,\r\n\tnavBarHidden : true,\r\n\t//layout : 'vertical'\r\n});\r\n\r\nvar viewbot = Ti.UI.createView({\r\n\t\r\n});\r\n\r\nwin1.add(viewbot);\r\n\r\nvar map1 = Ti.Map.createView({\r\n\tmapType : Ti.Map.STANDARD_TYPE,\r\n\tanimate : true,\r\n\tregion : {\r\n\t\tlatitude : 37.423156,\r\n\t\tlongitude : -122.084917,\r\n\t\tlatitudeDelta : 0.01,\r\n\t\tlongitudeDelta : 0.01\r\n\t},\r\n\tregionFit : true,\r\n\tannotations : [Ti.Map.createAnnotation({\r\n\t\tlatitude : 37.423156,\r\n\t\tlongitude : -122.084917,\r\n\t\timage : '/images/MapPin.png'\r\n\t})],\r\n\tuserLocation : true,\r\n\theight : Ti.UI.Fill\r\n});\r\nviewbot.add(map1);\r\n\r\nvar square1 = Ti.UI.createView({\r\n\theight : 20,\r\n\twidth : 20,\r\n\tbackgroundColor : 'red',\r\n\tbottom : 10,\r\n\tleft : 10,\r\n\t//zIndex: 1\r\n});\r\nviewbot.add(square1);\r\n\r\nwin1.open(); \r\n{code}\r\n{panel}", "attachment": [], "flagged": false, "summary": "Android: Views added to a Map View can't be seen", "creator": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "subtasks": [], "reporter": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "environment": "- Android 2.2 Google APIs emulator\r\n- Titanium Mobile SDK 2.1.0.GA\r\n- Titanium Studio 2.1.0.201206251749\r\n", "comment": { "comments": [ { "id": "208213", "author": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "body": "The fix here is simple. There is no bug. Do not try and add the square1 to the map view, instead add the square1 to the win1 just as map1 is. Your layout property for the win1 is set to vertical, this will drop the red square below the map view and out of sight. That is why it is not visible. If you comment out the \"vertical\" property, you will see the red square in the correct position over map1. ", "updateAuthor": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-07-17T16:49:07.000+0000", "updated": "2012-07-17T16:49:07.000+0000" }, { "id": "208229", "author": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "body": "Carter, your \"fix\" will not work universally. Keep in mind that the testcase in this ticket is a simplified example. If the MapView is in another less-than-fullscreen view, and that view has other elements in it that need to be arranged vertically, and we want the square positioned in/on the MapView (let's say right in the middle for example), then we have no way to accomplish this without a kludgy workaround of putting the MapView inside another absolute-layout view. This seems silly, because MapView decends from View, so we should be able to add anything to it we want...directly.", "updateAuthor": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "created": "2012-07-17T19:35:13.000+0000", "updated": "2012-07-17T19:35:13.000+0000" }, { "id": "208325", "author": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "body": "Shawn,\r\n\r\nAs you know, the two mobile operating systems, iOS and Android, were designed slightly differently and thus work a bit differently. In iOS, every UI component is view based. For example, a button in iOS sits in a transparent view, just as the mapView sits in its own view. On android however, this works differently. A button is just a button, there is no view associated with it, it is its own entity. The same with the mapViews in android, it is its own entity. Just like you can't add a view to a button in android, you can't add views to mapViews in android. This is not our design, rather the native behavior of the android operating system. So to make your code more appropriate for cross-platform use, the method I posted above to overlay a view over a map is the best way. I hope this clears up your question and issue. Let me know if you still have any more questions.\r\n\r\nCarter\r\n\r\nPS: I added another test code that shows that if you manually create a view and put it in the window. Then add the mapView and overlay to it, the overlay will show as expected in both platforms. This confirms what I said in this comment. ", "updateAuthor": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-07-18T10:53:35.000+0000", "updated": "2012-07-18T10:53:35.000+0000" }, { "id": "208331", "author": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "body": "Carter, thanks for the thorough explanation. You viewbot view is the current workaround I am using.\r\n\r\nPerhaps this bug ought to be modified then, to issue a console warning or error when an attempt is made to add another visual element to a MapView.", "updateAuthor": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "created": "2012-07-18T11:03:29.000+0000", "updated": "2012-07-18T11:03:29.000+0000" }, { "id": "208339", "author": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "body": "Your welcome Shawn. Yes, the name mapView is a bit misleading in that it seems as if you should be able to add views to it. But in general its usually good practice to have a parent view, such as viewbot, to add everything too so that you can have the most control over the behavior of a subset of views. Would you mind closing this jira ticket if you have no further problems? Thanks", "updateAuthor": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-07-18T11:20:03.000+0000", "updated": "2012-07-18T11:20:03.000+0000" }, { "id": "208350", "author": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "body": "Carter, I would close it if I could, but I don't have the power!\r\n\r\nAlthough I could also just edit this ticket to change it into a request for a console warning or error when an attempt is made to add another visual element to a MapView.\r\n", "updateAuthor": { "name": "bitshftr", "key": "bitshftr", "displayName": "Shawn Lipscomb", "active": true, "timeZone": "America/New_York" }, "created": "2012-07-18T11:32:30.000+0000", "updated": "2012-07-18T11:32:30.000+0000" }, { "id": "208361", "author": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "body": "All set, I resolved the ticket and marked as invalid. Thanks for your patience with this.", "updateAuthor": { "name": "clathrop", "key": "clathrop", "displayName": "Carter Lathrop", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-07-18T11:46:56.000+0000", "updated": "2012-07-18T11:46:56.000+0000" }, { "id": "286000", "author": { "name": "shossain", "key": "shossain", "displayName": "Shak Hossain", "active": false, "timeZone": "America/Los_Angeles" }, "body": "Closing as per feedback from Shawn.", "updateAuthor": { "name": "shossain", "key": "shossain", "displayName": "Shak Hossain", "active": false, "timeZone": "America/Los_Angeles" }, "created": "2013-12-27T20:35:18.000+0000", "updated": "2013-12-27T20:35:18.000+0000" } ], "maxResults": 8, "total": 8, "startAt": 0 } } }