Wow, I&#39;ve been working on making OpenLayers work more like Google on mobile devices for the last few weeks with varied amounts of success.  I finally joined the mailing list and the first e-mail I get is this one!  I&#39;d like to join in the fray and work together to get this done right.<br>
<br>I&#39;ve got an existing successful iPhone application that I&#39;m porting to other platforms.  There&#39;s a lot that I want to add to my app&#39;s mapping functionality and OpenLayers looks like it would fit the bill great, but the user experience is just not as smooth as Google and Bing provide.  The headache that I&#39;ve been working on is getting layers that extend from OpenLayers.Grid to act more like Google where when you zoom in or out it simply scales the tiles you already have loaded then loads new tiles on top of them.  To accomplish this we need to rethink the way that Grid layers layout their tiles so that there are multiple layers of tiles within one Grid (not just foreground and background img&#39;s in Image.js).<br>
<br>The approach that I have working is to use HTML tables rather than fixed height/width div&#39;s to house the individual images the make up a tiled grid...then set the height/width of the img tags to 100%/100% so that all tiles are always trying to scale to as large as they can be.  If you add these img&#39;s to each cell in the table, then as you scale the whole table up or down, the tile images scale appropriately without having to constantly manually recalculate the size and position of every loaded tile.   Then, for each pre-configured zoom level you create one of these tables and make sure that each table understands its relationship to the current resolution then layer each table on top of each other.  As the zoom level changes fractionally, we scale ALL the tables appropriately then recalculate to see which of our tables should be requesting tiles and tell the Grid to work on that table.  This works and gives good fractional zooming to Grid layers (I&#39;ve had a working version of this, but wasn&#39;t happy with all my code so I&#39;m presently in the process of refactoring it).  I&#39;m not completely done, I still have some minor positioning issues, but I&#39;m definitely happy with the general approach.<br>
<br>I also added a nice fade-in effect for newly loaded tiles which makes the UI appear MUCH less clunky (it&#39;s often funny how a little visual change can make something look so much more professional).  I&#39;ll share it when I get some time.<br>
<br>I&#39;d like to collaborate on porting OpenLayers to mobile devices.  May I suggest that we organize together and come up with an approach where we work together on the actual implementation of each of our issues?<br>
<br>Thanks,<br><br><br>-Beau<br><br><br><br><div class="gmail_quote">On Thu, Dec 23, 2010 at 9:14 AM, Bob Basques <span dir="ltr">&lt;<a href="mailto:Bob.Basques@ci.stpaul.mn.us">Bob.Basques@ci.stpaul.mn.us</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
  

  
  <div style="margin: 4px 4px 1px; line-height: normal; font-variant: normal;">
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">Benoit,</font>    </p>
<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">I&#39;m old school in all this, so my ideas about a generic approach to things will likely seem old fashioned.</font>    </p>
<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">My first stab at putting together a gesture based interface would be to use some sort of control overlay in the map area.  This is mostly to provide instant feedback to the users more than anything.</font>    </p>

<br>      <br>
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">Some important points (I think):</font>    </p>
<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">** Symbols for zooming in (+) and out (-) that are right on the map it self. This might actually be considered a failsafe mode, where all other modes don&#39;t work for a device, and would use essentially existing capabilities as far as user controls go in a mapping environment.  Dragging seems to be a universal capability (so far), that can be implemented on (nearly) all devices.</font>    </p>

<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">** Some sort of (fairly comprehensive) device type detection (or user setup control for a device type) will need to be in place.</font>    </p>
<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">** With the building of a &quot;failsafe&quot; mode, and making it always available, the process of adding the gesture aspects seem to fall into the category of add-on.  As an aside here, with the advent of Netbook / Tablet devices becoming more prevalent, there may be some room here to add in some key-macro navigation tools as well as an optional navigation toolset, but this is likely only interesting to myself.  But if this type of approach of allowing for more than one type of navigation toolset were used, I think the different platform specifics can be more easily approached.   Am I talking about a navigation conduit here?  Something that is standardized in some form, that many different types of navigation tools could be developed against?  There are certain work processes that might require direct access to a navigation tool in a very specific manner for example, that a framework like this might help with during the development.</font>    </p>

<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">** Associated with the navigation are layer choosers of some sort.  Displaying many layer option (or even many of anything) is a problem on a smaller form factor device.  I think this is an associated and just as important aspect of the gesture controls (for mapping) as is the navigation.  While most map based solutions may only present a few layers to the end user, I have systems in place that have hundreds of layers available, and it&#39;s very difficult to present this type of information to the typical user, let alone ones you might have the option of doing a little one on one training with.</font>    </p>

<br>      <br>
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">I would prefer to use a common set of code to accomplish this all with some sort of auto-detection of device on the client side.  The gestures themselves seem to be varied in their implementation across vendor products to one degree or another.  Is there room here for some sort of user settings/preferences (like in a desktop application) where the user can decide (based on the device capabilities) what gestures can be enabled. There could be defaults for known devices.</font>    </p>
<div class="im">
<br>      
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <font face="Comic Sans MS" size="3">bobb</font>    </p>
<br>      <br>
    <p style="margin-bottom: 0pt; margin-top: 0pt;">
      <br>
      <br>
      &gt;&gt;&gt; Benoit Quartier &lt;<a href="mailto:benoit.quartier@camptocamp.com" target="_blank">benoit.quartier@camptocamp.com</a>&gt; wrote:<br>    </p>
    </div><div class="im"><table style="margin: 0pt 0pt 0pt 15px; font-size: 1em;" bgcolor="#f3f3f3" border="0">
      <tbody><tr>
        <td>
          <div style="padding-left: 7px; border-left: 1px solid rgb(5, 5, 5);">
            <p style="margin-bottom: 0pt; margin-top: 0pt;">
              Bob,<br><br>            </p>
            <div class="gmail_quote">
              <p style="margin-bottom: 0pt; margin-top: 0pt;">
                On Tue, Dec 21, 2010 at 5:40 PM, Bob Basques <span dir="ltr">&lt;<a href="mailto:Bob.Basques@ci.stpaul.mn.us" target="_blank">Bob.Basques@ci.stpaul.mn.us</a>&gt;</span> wrote:<br>              </p>
              <blockquote class="gmail_quote" style="margin: 0pt; border-left: 1px solid rgb(204, 204, 204); padding-left: 0pt;">
                <div style="margin: 4px 4px 1px; line-height: normal; font-variant: normal;">
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <font face="Comic Sans MS" size="3">Benoit,</font>                  </p>
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <br>
                                      </p>
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <font face="Comic Sans MS" size="3">I couldn&#39;t get the zooming to work at all on the N900. But I don&#39;t count that as a fault.</font>                  </p>
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <br>
                                      </p>
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <font face="Comic Sans MS" size="3">I understand the complexities here, especially with regard to the multi-touch aspects vs single touch enabled devices. I think that in the near term the gesture aspects are going to NEED to be targeted at vendor specifics in order to take full advantage of each of them. Hopefully this will flesh out to a standard from the best available, but, in the near term, I&#39;m interested in seeing a process that works for single touch (Could be all phone/mobile devices??) as a foundational chunk of coding. Hopefully this approach would get as many functional mobile devices accounted for as possible. Then it makes sense to attack the vendor specific (extra) capabilities. It seems to be easier to design for the masses where possible (from my experience), and then to enhance for the specialties, don&#39;t you think?</font>                  </p>

                </div>
              </blockquote>
              <div>
                <p style="margin-bottom: 0pt; margin-top: 0pt;">
                  Yes, I fully agree. That&#39;s why we didn&#39;t begin with Apple gestures. But as you wrote, in the near term, we will need to implement these vendor specifics gestures.<br><br>It would be great to have a set of single touch events that works on all (as much as possible) devices and, additionally, a set of vendor specific gesture. What would they be? Double tap to zoom in, triple tap to zoom out?<br>
                </p>
              </div>
              <div>
<br>                  
              </div>
              <blockquote class="gmail_quote" style="margin: 0pt; border-left: 1px solid rgb(204, 204, 204); padding-left: 0pt;">
                <div style="margin: 4px 4px 1px; line-height: normal; font-variant: normal;">
<br>                    
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <br>
                                      </p>
                  <p style="margin-bottom: 0pt; margin-top: 0pt;">
                    <font face="Comic Sans MS" size="3">I think there are options available for addressing these ideas, if anyone else is interested.</font>                  </p>
                </div>
              </blockquote>
              <div>
                <p style="margin-bottom: 0pt; margin-top: 0pt;">
                  I am interested but I am not sure to understand what you mean? Could you please elaborate?<br><br><br>
                </p>
              </div>
            </div>
          </div>
        </td>
      </tr>
    </tbody></table>
  </div></div>

<br>_______________________________________________<br>
Dev mailing list<br>
<a href="mailto:Dev@lists.osgeo.org">Dev@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/openlayers-dev" target="_blank">http://lists.osgeo.org/mailman/listinfo/openlayers-dev</a><br>
<br></blockquote></div><br>