PROVIDING HOTSPOTS TO USER DEVICES WITHIN SERVER-CONTROLLED ZONES

Information

  • Patent Application
  • 20160029164
  • Publication Number
    20160029164
  • Date Filed
    September 10, 2015
    9 years ago
  • Date Published
    January 28, 2016
    8 years ago
Abstract
A user installs a hotspot alert application on their mobile device. The application employs the location technology of the user device to transmit the location of the device, and thus the location of the user. The location can be transmitted to a server located in a hotspot tracking system. By establishing the location of the user, the server may search for hotspots on a database stored on the system. The server establishes the dimensions of a hotspot zone around the user's location and transmits the hotspots and the zone dimensions to the application on the user device. The application monitors the location of the user device and deliver's configured alerts to the user when approaching a hotspot. When the device leaves a zone or remains idle for a configured amount of time, the device requests and receives an updated zone of hotspots.
Description
TECHNICAL FIELD

The present disclosure relates generally to mobile hotspot tracking, and more particularly to delivering server-controlled hotspot zones to a mobile device.


BACKGROUND

Location data from a mobile device can be used for numerous applications. There are applications that use the location data for locating friends, playing games, and assisting a user with directions. The location data can also be used to alert a user when the user and the user's device are in the vicinity of a hotspot. A hotspot is any business, institution, or location that would be of interest to a user. For example, a user may choose to be alerted every time the user nears a particular store or restaurant, or the server may identify a hotspot as a nearby store that the user frequents and that is currently offering a promotion or coupon.


Unfortunately, hotspot information is constantly changing. New stores are built, promotions are updated, and the user location changes. A user may desire constantly updated hotspot information, but the mobile devices are not typically capable of maintaining a database of all the hotspots and hotspot marketing data. Trying to maintain this data may have an adverse effect on the data storage capacity of the device, the battery life of the device, the required data transmission capacity, or other aspects of operating a mobile device.


Conversely, tracking the location of the user device by the server and continually providing updates with hotspot data as the mobile device changes locations also adversely affects the battery, storage capacity, and data transmission capacity of the device.


Thus, a need in the art exists for systems and methods that improve upon one or more of the above-described limitations.


SUMMARY OF THE INVENTION

An aspect of the present invention provides a computer-implemented method for delivering server-controlled hotspot zones to a mobile device. A user installs a hotspot alert application (“HAA”) on their mobile device. The HAA employs the location technology of the user device to determine a location of user device. The location can be transmitted to a server located in a hotspot tracking system (“HTS”). By establishing the location of the user, the HTS may search for hotspots on a database stored on the system. The HTS establishes the dimensions of a hotspot zone substantially surrounding the user's location. The HTS transmits the hotspots and the zone dimensions to the HAA. The HAA monitors the location of the user device and may deliver configured alerts to the user when approaching a hotspot. Alternatively, the HAA may notify the server when the user is approaching a hotspot, and the server may determine whether to alert the user. When the device leaves a zone or remains idle for a configured amount of time, the device requests and receives an updated zone of hotspots.


Another aspect of the present invention provides a computer program product that is installed on a user's device and on a server located in an HTS for delivering server-controlled hotspot zones to a mobile device. The computer program product includes a non-transitory computer-readable storage device having computer-readable program instructions stored therein. The computer-readable program instructions include computer program instructions for transmitting the user's location from the user device to the HTS server; searching for hotspots on a database stored on the system; establishing the dimensions of the hotspot zone around the user's location; transmitting the hotspots and the zone dimensions to the user device; monitoring the location of the device and alerting the user when approaching a hotspot; requesting and receiving updated hotspot information when the device leaves a zone or remains idle for a configured amount of time.


Another aspect of the present invention provides a system for delivering server-controlled hotspot zones to a mobile device. The HAA is configured for transmitting the user's location to the HTS server, monitoring the location of the device, and requesting and receiving updated hotspot information when the device leaves a zone or remains idle for a configured amount of time. The HAA also may alert the user when approaching a hotspot or may notify the server when the user is approaching a hotspot, and the server may determine whether to alert the user. The system includes an HTS server configured for receiving the location data; searching for hotspots on a database stored on the HTS system; establishing the dimensions of the hotspot zone around the user's location; and transmitting the hotspots and the zone dimensions to the user device.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram depicting an operating environment of a hotspot alert application (“HAA”), in accordance with certain exemplary embodiments.



FIG. 2 is a block flow diagram depicting a method for supplying a user device with proximate hotspots, in accordance with certain exemplary embodiments.



FIG. 3 is a block flow diagram depicting a method for generating and transmitting hotspots to a user device, in accordance with certain exemplary embodiments.





DETAILED DESCRIPTION
Overview

The exemplary embodiments provide a hotspot alert application (“HAA”) that can utilize a user's location data for delivering server-controlled hotspot zones to a mobile device. A user installs an HAA on their mobile device. The HAA can provide a user interface for entering configuration information. The HAA employs the Global Positioning System (“GPS”) location technology or other location identifying technology of the user device to transmit the location of the device, and thus the location of the user. This location can be transmitted to a server located in a hotspot tracking system (“HTS”). The HAA might gather the location data directly from the device operating system, or the HAA might request the location from another location-based application operating on the phone.


The HTS receives the location data from the user device and identifies the geographical location of the device. The HTS then accesses a database for hotspot information in the vicinity of the user device. The hotspot information may be anything that would be of interest to the user. The category of hotspot information accessed might be user configured or may be selected by the HTS server based on the user's prior activities, interests, or suggestions. Examples of hotspots that may be identified by the server for transmitting to the user device might include, but would not be limited to, restaurants, stores, or other businesses frequented by the user, businesses currently offering a sale or promotion, businesses currently offering an electronic coupon, tourist attractions, museums, friends identified by their devices, or any other identifiable entity in which the user may be interested.


The HTS identifies the hotspots in the user's vicinity and uses the density or quality of the hotspot information to establish the size and boundaries of the hotspot zone to transmit to the user device. The HTS may limit the size of the hotspot zone to prevent any adverse effects caused by transmitting a quantity of data that is too large for the user device and the system to operate efficiently. For example, if the amount of hotspot data transmitted is too large, the data may require enough capacity on the data storage unit of the device to affect the normal operating of the device. Alternatively, if the size of the hotspot zone is too small, the HTS may be forced to transmit a new zone of hotspots to the device too frequently to be practical. For example, if the hotspot zone data were transmitted too frequently, it might consume the battery life of the device.


The HTS may additionally prioritize the hotspot data. Based on user input or an analysis of user historical data, such as purchasing history or website usage, the HTS may provide a ranked list of the hotspots to the user device. This ranked list may be used by the HAA to determine when or how to alert the user to the proximity of a particular hotspot. For example, the HAA may display all hotspots on a map of the zone, but only alert the user when they are approaching one of the top ten ranked hotspots.


The HAA on the user device receives the zone boundaries and the hotspot information. The HAA may be an application running on the user device that is configured for any type of hotspot locating activity. For instance, the HAA may be an application that is configured to alert a user to restaurants or stores that are a favorite of the user or are currently offering a coupon. The HAA may alert a user to museums or tourist attractions. The HAA may alert a user of other devices operating in the area that may be contacts of the user. The HAA may be focused on alerting a user to any other business or entity that the user or the server configures the HAA to monitor.


After receiving the hotspot and zone information, the HAA may display the information on a map or other grid via the user interface of the HAA. Additionally or alternatively, the HAA may display the information to the user in any other format that can convey the information, such as a simple listing of each hotspot and the distance away from the user that each hotspot is located. The HAA may further provide a route to the hotspot upon request from the user.


If displaying the information on a map view, the HAA may expand or collapse the data displayed to the user depending on the density of the data. For example, if a large number of hotspots are located in a localized area, the HAA may group hotspots together and show the grouping in a single icon or notation. An example of this may be a shopping complex that contains a quantity of hotspots too great to display on a user device. The display may simply show a shopping complex notation and list the number of hotspots contained at that location or any other manner of representing the group of hotspots. As the user approaches the dense hotspot, the grouped hotspot may expand to show the individual hotspots in that area.


After receiving the hotspot information, the mobile device continues to monitor the location of the user device. If the device approaches a hotspot, the HAA may perform any alert function configured by the user. For instance, the HAA may alert a user when the user device is within a configured range of the hotspot, such as within a block of the hotspot. The alert may additionally take any configured form desired by the user. In exemplary embodiments, the HAA may use the alert internally or may provide an audible alert, a vibration, a visible alert, such as showing the hotspot details on the display of the user device, an e-mail, or any other configurable alerting procedure. In an alternate embodiment, the HAA may alert the HTS that the device is approaching a hotspot. The HTS may perform any alert function configured by the user or store the alert for later use. The HTS may send an alert to the HAA or to another location. For example, the HTS may send an email, push notification, text message, or another communication to the user.


The HAA can be embodied as a stand-alone application program or as a companion program to a web browser, for example, as a companion program to a Hypertext Markup Language revision 5 (“HTML5”) compliant web browser or other type of web browser having messaging and storage capabilities. While certain embodiments are described in which parts of the HAA are implemented in software, it will be appreciated that one or more acts or functions of the HAA may be performed by hardware, software, or a combination thereof, as may be embodied in one or more computing systems.


Users may, in appropriate circumstances, limit or otherwise affect the operation of the features disclosed in the specification. For example, users may be given an initial opportunity to opt-in or opt-out of the collection or use of certain data or the activation of certain features. In addition, a user may change the manner in which the features are employed, including for situations in which a user may have concerns regarding his privacy. Instructions may be provided to notify the users regarding policies about the use of information, including personally identifiable information and receipt information, and manners in which the users may affect such use of information.


System Architecture

Turning now to the drawings, in which like numerals represent like (but not necessarily identical) elements throughout the figures, exemplary embodiments of the present invention are described in detail. FIG. 1 is a block diagram depicting an operating environment 100 for a hotspot alert application (“HAA”), in accordance with certain exemplary embodiments.


Referring to FIG. 1, the exemplary operating environment 100 includes a user network device 110 associated with a user 101, a hotspot marketing system 150, and a hotspot tracking system (“HTS”) 160. The user device 110 may be a mobile device, (for example, notebook computer, tablet computer, netbook computer, personal digital assistant (PDA), video game device, GPS locator device, cellular telephone, smartphone, or other mobile device), or other appropriate technology that may include or may be coupled to a web browser application module 112 or other communication module 117. The user device 110 may employ a host CPU 116 to process the operations of the user device 110.


In certain exemplary embodiments, the web browser application 112 is an HTML5 compliant web browser. HTML5 compliant web browsers include a cross-document messaging application programming interface (API) and a local storage API that previous HTML versions did not have. The cross-document messaging API of HTML5 compliant web browsers enables documents, such as web pages, to communicate with each other. For example, a first document can send a message to a second document requesting information. In response, the second document can send a message including the requested information to the first document. The local storage API of HTML5 compliant web browsers enables the web browser to store information on a client device upon which the web browser is installed or is executing, such as the user device 110. Websites also can employ the local storage API to store information on a client device. Other web browsers having cross-document messaging and/or local storage capabilities also may be used in certain exemplary embodiments.


The user 101 can use the web browser application 112 to view, download, upload, or otherwise access documents or web pages via a distributed network 105. The network 105 includes a wired or wireless telecommunication system or device by which network devices (including devices 110, 150, and 160) can exchange data. For example, the network 105 can include a local area network (“LAN”), a wide area network (“WAN”), an intranet, an Internet, storage area network (SAN), personal area network (PAN), a metropolitan area network (MAN), a wireless local area network (WLAN), a virtual private network (VPN), a cellular or other mobile communication network, Bluetooth, NFC, or any combination thereof or any other appropriate architecture or system that facilitates the communication of signals, data, and/or messages. Throughout the discussion of exemplary embodiments, it should be understood that the terms “data” and “information” are used interchangeably herein to refer to text, images, audio, video, or any other form of information that can exist in a computer based environment.


The web browser application 112 can interact with web servers (or other computing devices) connected to the network 105, web server 151 of the hotspot marketing system 150, and the web server 161 of the HTS 160.


The user device 110 may employ a communication module 117 to communicate with the web server 161 of the HTS 160 or other servers. The communication module 117 may allow devices to communicate via technologies other than the network 105. Examples might include a cellular network, radio network, or other communication network.


The user device 110 may include a digital wallet application module 111. The digital wallet 111 may encompass any application, hardware, software, or process the user device 110 may employ to assist the device to complete a purchase transaction. The digital wallet 111 can interact with the web browser application 112 or can be embodied as a companion application of the web browser application 112. As a companion application, the digital wallet 111 executes within the web browser application 112. That is, the digital wallet 111 may be an application program embedded in the web browser application 112.


The user device 110 may include an HAA 115. The HAA 115 can interact with the web browser application 112 or be embodied as a companion application of the web browser application 112 and execute within the web browser application 112. In an exemplary embodiment, the HAA 115 may further be embodied as a companion application of the digital wallet 111 and execute within the digital wallet 111. The HAA 115 may employ a software interface that may open in the digital wallet application 111 or may open in the web browser application 112. The interface can allow the user 101 to configure the HAA 115 and the user account on the HTA 160.


The HAA 115 can be used to send device location data to the HTS 160 and receive a hotspot zone from the HTS 160. The HTS 160 that develops the hotspot zone can include a set of computer-readable program instructions, for example, using JavaScript, that enable the HTS 160 to interact with the HAA 115.


The user device 110 includes a data storage unit 113 accessible by the HAA 115 and the web browser application 112. The exemplary data storage unit 113 can include one or more tangible computer-readable media. The data storage unit 113 can be stored on the user device 110 or can be logically coupled to the user device 110. For example, the data storage unit 113 can include on-board flash memory and/or one or more removable memory cards or removable flash memory.


The user device 110 may include a location-based application 114 that the HAA 115 or the HTS 160 may utilize to access location data for the user device 110. Examples of applications that may utilize the location data, and thus may make it available to the HTS 160 or HAA 115, may include, but would not be limited to, Global Positioning System (“GPS”) location technology or other location identifying technology of the user device, business finder applications such as AROUNDME, location based social networks such as FOURSQUARE, location based gaming such as GOWALLA, or friend locater applications such as GOOGLE LATITUDE. Additionally or alternately, the user device 110 may be capable of providing location data directly from the host CPU 116. The host CPU 116 may provide the location data to the HAA 115 or may be configured to transmit the location data directly to the HTS 160.


The HTS 160 utilizes a HTS server 161 operating a hotspot tracking application 164. The HTS server 161 operating the hotspot tracking application 164 may represent the computer implemented system that the HTS 160 employs to configure user accounts, create and maintain user profiles, collect the location data, communicate with the hotspot marketing system 150, develop proximate hotspot maps and zones, and submit the data to the user 101. The HTS website 163 may represent any web-based interface that allows users to interact with the HTS 160 to configure the user accounts and change account settings. The HTS server 161 can communicate with one or more hotspot marketing systems 150, and a user device 110 via any available technologies. These technologies may include, but would not be limited to, an Internet connection via the network 105, email, text, instant messaging, or other suitable communication technologies. The HTS 160 may include a data storage unit 162 accessible by the server 161 of the HTS 160. The data storage unit 162 can include one or more tangible computer-readable storage devices.


The hotspot marketing system 150 utilizes a hotspot marketing system server 151. The hotspot marketing system server 151 may represent the computer-implemented system that the hotspot marketing system 150 employs to provide hotspot identities, locations, marketing information, and descriptions to the HTS 160. The hotspot marketing system 150 may represent any number of systems that may be polled by the HTS 160 to gather hotspot information. For example, the hotspot marketing system 150 may be the marketing system of a product manufacturer or a service provider. The hotspot marketing system 150 may be a social network system of a user that can provide preferences and historical data of a user's activities, such FACEBOOK, GOOGLE+, or LINKEDIN. The hotspot marketing system 150 may be a coupon aggregator or provider. The hotspot marketing system 150 may be a mapping program such as GOOGLE MAPS or MAPQUEST. The hotspot marketing system 150 may be any other service or system that may provide information that the HTS 160 can use to define a hotspot zone and prioritize the hotspots.


The hotspot marketing system 150 can communicate with an HTS 160 and user devices 110 via any available technologies. These technologies may include, but would not be limited to, an Internet connection via the network 105, email, text, instant messaging, or other suitable communication technologies. The hotspot marketing system 150 may include a data storage unit 152 accessible by the server 151 of the hotspot marketing system 150. The data storage unit 152 can include one or more tangible computer-readable storage devices.


It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers and devices can be used. Moreover, those having ordinary skill in the art having the benefit of the present disclosure will appreciate that the user device 110, hotspot marketing system 150, and HTS 160 illustrated in FIG. 1 can have any of several other suitable computer system configurations. For example, a user device 110 embodied as a mobile phone or handheld computer may not include all the components described above.


System Process

The components of the exemplary operating environment 100 are described hereinafter with reference to the exemplary methods illustrated in FIG. 2-3. The exemplary embodiments can include one or more computer programs that embody the functions described herein and illustrated in the appended flow charts. However, it should be apparent that there could be many different ways of implementing aspects of the exemplary embodiments in computer programming, and these aspects should not be construed as limited to one set of computer instructions. Further, a skilled programmer would be able to write such computer programs to implement exemplary embodiments based on the flow charts and associated description in the application text. Therefore, disclosure of a particular set of program code instructions is not considered necessary for an adequate understanding of how to make and use the exemplary embodiments. Further, those skilled in the art will appreciate that one or more acts described may be performed by hardware, software, or a combination thereof, as may be embodied in one or more computing systems.



FIG. 2 is a flow chart depicting a method 200 for supplying a user device with proximate hotspots, in accordance with certain exemplary embodiments.


With reference to FIGS. 1 and 2, in block 205, the hotspot tracking system (“HTS”) 160 installs computer-readable program instructions on the HTS server 161 for interacting with the hotspot alert application (“HAA”) 115 on the user device 110. Additionally, the HTS 160 installs computer-readable program instructions on the HTS server 161 for interacting with the hotspot marketing system 150. In an exemplary embodiment, these computer-readable program instructions may be implemented as an embedded script, such as JavaScript, in the HTS server 161. The program instructions may be embodied as a hotspot tracking application 164.


In block 210, the user 101 installs an HAA 115 on the user device 110. In certain exemplary embodiments, the user 101 may navigate to a website of a provider of the HAA 115 and download and install the HAA 115. The website that provides the HAA 115 may be the HTS website 153. The HAA 115 may be embedded in a digital wallet 112 on a user device 110. The user 101 may utilize a user interface of the HAA 115 for configuration. The user 101 may configure privacy settings provided by the HAA 115.


Additionally, the user 101 may communicate with the computer-readable program instructions on the HTS 160 to establish user identification and account configuration. The communication with the HTS 160 may be made via any available technology including, but not limited to, an Internet connection via the network 105, text, email, or a cellular connection. On the HTS 160 and the HAA 115, the user 101 may configure the categories of hotspots that are monitored. The user 101 may additionally configure privacy settings provided by the HTS 160.


The HAA 115 may additionally or alternatively communicate with the HTS 160 to establish the format in which the hotspot data should be transmitted. For example, an HAA 115 that does not employ a map display feature, may only require a listing of hotspots. An HAA 115 may request any other format or data that is available from the HTS 160.


The user 101 may additionally configure the alerting mechanism of the HAA 115. The HAA 115 may provide an audible alert, a vibration, a visible alert, such as showing the hotspot details on the display of the user device, or any other configurable alerting procedure. The alert may additionally or alternatively be incorporated by any other application that could benefit from the hotspot alert.


In block 215, the user 101 initiates the HAA 115 by actuating a physical or virtual button, making a motion such as a “tap” or swipe with the user device 110, speaking a voice command, or performing any other initiation process. The HAA 115 transmits to the HTS 160 the location of the user device 110. The HAA 115 may be configured to access the location data directly from the host CPU 116 of user device 110. The user device 110 may have the capability, through computer hardware or software, or a combination thereof, to determine the geographic coordinates of the location of the user device 110. For example, the user device 110 may utilize the Global Positioning System (“GPS”) to determine its location.


Additionally or alternatively, the user device 110 may include a location-based application 114 that the HAA 115 or the HTS 160 may utilize to access location data for the user device 110. Examples of applications that may utilize the location data, and thus may make it available to the HTS 160, may include, but would not be limited to, business finder applications such as AROUNDME, location based social networks such as FOURSQUARE, location based gaming such as GOWALLA, or friend locater applications such as GOOGLE LATTITUDE.


In block 220, the HTS 160 gathers hotspot location data and transmits the location data to the user device 110. The details of this step will be discussed in further detail with reference to method 220 of FIG. 3.


In block 225, the user device 110 incorporates the hotspot data into the user interface of the HAA 115. The HAA 115 may display the information on a map or other grid via the user interface of the HAA. Additionally or alternatively, the HAA 115 may display the information to the user in any other format that can convey the information, such as a simple listing of each hotspot and the distance away from the user that each hotspot is located. The HAA 115 may further provide a route to a hotspot upon request from the user. The user 101 may elect to operate the HAA 115 in the foreground of the host CPU 116 operating system and provide substantially instant alerts as the user 101 moves through the hotspot zone. The HAA 115 may alternatively operate in the background of the operating system and store the hotspot alerts for later access by the user 101.


In block 230, the HAA 115 monitors the location of the user device 110 as it moves through the hotspot zone. The HAA 115 compares the location of the user device 110 to known hotspots identified on the most recent hotspot zone. The HAA 115 continually or intermittently determines if the user device is within a configured distance from a hotspot.


In block 235, the HAA 115 determines if a hotspot is being approached. For example, if a user 101 is walking through a shopping district with the user device 110 and comes within a specified distance of a hotspot, such as one block, the HAA 115 recognizes the approached hotspot. If a hotspot is being approached, the method 200 follows the “YES” branch of block 235 to block 237. If no hotspot is being approached, the method 200 follows the “NO” branch of block 235 to 230.


Following the “NO” branch of block 235 to block 230, the HAA 115 continues to monitor the location of the user device 110 as previously described.


Following the “YES” branch of block 235 to block 237, a hotspot alert is triggered when the user device 110 moves within a configured range of a hotspot. In exemplary embodiments, the HAA 115 may use the alert internally or may provide an audible alert, a vibration, a visible alert, such as showing the hotspot details on the display of the user device, an e-mail, or any other configurable alerting procedure.


In an alternate embodiment, the HAA 115 may alert the HTS 160 that the device is approaching a hotspot. The HTS 160 may perform any alert function configured by the user or store the alert for later use. The HTS 160 may send an alert to the HAA 115 or to another location. For example, the HTS 160 may send an email, push notification, text message, or another communication to the user.


In an alternative embodiment, the HAA 115 may be configured to alert the user 101 of only the higher priority hotspots. As discussed in the details of method 220 of FIG. 3, the hotspot data may be prioritized by the HTS 160. The HAA 115 may use the priority of the hotspot data to determine which hotspots will trigger an alert to the user 101. For example, the user 101 may desire to limit the alerts to the 10 highest priority hotspots in a given zone. Alternatively, the user 101 may configure the HAA 115 to alert the user 101 to every hotspot in the zone.


In block 240, if the user device 110 approaches a configured distance from the boundary of the hotspot zone, the method 200 follows the “YES” branch of block 240 to block 220. If the user device 110 has not approached a configured boundary of the hotspot zone, the method 200 follows the “NO” branch of block 240 to block 245. In an alternate embodiment of the application, the HAA 115 may require the user device 110 to completely exit the boundaries of the hotspot zone to follow the “YES” branch of block 240.


Following the “YES” branch of block 240 to block 220, the method requests and receive a refreshed hotspot zone. As the user device 110 has left the boundaries of the previous hotspot zone, the HAA 115 will have no hotspot data to display to the user 101 or monitor for alerts. A new hotspot zone with a new list of hotspots is transmitted to the user device 110.


Following the “NO” branch of block 240 to block 245, the user device 110 determines if the user device 110 has received a new hotspot zone in a configured amount of time. For instance, if a user device 110 has remained in one location for a configured time or has not encountered any hotspots for a configured time, the method 200 will determine that the user device 110 is idle and follow the “YES” branch of block 245 to block 220. A new hotspot zone with a new list of hotspots is transmitted to the user device 110. The idle time required to trigger the “YES” branch of block 245 is configurable by the user 101 or the HAA 115. For example, the idle time required might be one hour, one day, one week, or any other time that is reasonable based upon the activities of the user 101.


If the device has not remained idle and has received a new hotspot zone within the configured time, the method 200 follows the “NO” branch of block 245 to block 230. The device will continue monitoring the location of the user device 110.


The method 200 continues until the user 101 deactivates the HAA 115 or the user device is shut down.



FIG. 3 is a flow chart depicting a method 220 for generating and transmitting hotspots to a user device, in accordance with certain exemplary embodiments.


With reference to FIGS. 1 and 2, in block 305 of method 220, the HTS 160 establishes and maintains current marketing and location data of hotspots that relate to a user 101. The hotspot information may be anything would be of interest to the user. The category of hotspot information accessed might be user configured or may be selected by the HTS server 161 based on the prior activities, interests, or suggestions of the user 101. Examples of hotspots that may be identified by the server 161 for transmitting to the user device 110 might include, but would not be limited to, restaurants, stores or other businesses frequented by the user 101, businesses currently offering a sale or promotion, businesses currently offering an electronic coupon, tourist attractions, museums, friends identified by their devices, or any other identifiable entity in which the user 101 may be interested.


The HTS 160 may access hotspot data from any system that may be polled by the HTS 160 to gather hotspot information. For example, the hotspot data may be gathered from a hotspot marketing system 150. A hotspot marketing system 150 may be the marketing system of a product manufacturer or a service provider. The hotspot marketing system 150 may be a social network system of a user that can provide preferences and historical data of a user's activities, a coupon aggregator or provider, a mapping system, or any other service or system that may provide information that the HTS 160 can use to define a hotspot zone and prioritize the hotspots.


In block 310, the HTS 160 receives the location of the user device 110. The HTS 160 stores the location of the user device 110 in the user account. In block 315, the HTS 160 identifies the hotspots in the vicinity. The HTS 160 may access the database maintained for the account of the user 101. The distance of each possible hotspot from the location of the user 101 is calculated and stored.


In block 320, the HTS 160 uses the density or quality of the hotspot information to establish the size of the hotspot zone to transmit to the user device 110. The HTS 160 may limit the size of the hotspot zone to prevent any adverse effects caused by transmitting a quantity of data that is too large for the user device 110 and the system to operate efficiently. For example, if the amount of hotspot data transmitted is too large, the data may require enough capacity on the data storage unit 113 of the user device 110 to affect the normal operation of the user device 110. Alternatively, if the size of the hotspot zone is too small then the HTS 160 may be forced to transmit a new zone of hotspots to the user device 110 too frequently to be practical. For example, if the hotspot zone data were transmitted too frequently, it might consume the battery life of the user device 110.


The size of the hotspot zone around the current location of the user device 110 can be determined based on the density or quality of the hotspot information. In an exemplary embodiment, the size of the hotspot zone may be established to encompass a configured number of hotspots in the proximity of the user device 110. For example, the size of the hotspot zone can be configured to encompass the specified number of hotspots that are closest to the user device 110 or that provide the highest priority hotspots around the user device 110. Thus, in an area of high concentration of available hotspots, the hotspot zone may be relatively small to capture the specified number of hotspots. Alternatively, in an area of lower concentration of available hotspots, the hotspot zone may be relatively large to capture the specified number of hotspots. Additionally, the size of the hotspot zone can take any suitable shape to encompass the specified hotspots.


The HTS 160 may additionally prioritize the hotspot data. Based on input of the user 101 or an analysis of historical data, such as purchasing history or website usage of the user 101, the HTS 160 may provide a ranked list of the hotspots to the user device 110. For example, the HTS 160 may be able to determine that a user 101 prefers a certain store or restaurant and rank it higher than an alternative restaurant even if the alternative restaurant is closer to the user 101 location. Thus, if the user 101 limits the number of hotspot alerts in a given zone, a lower ranked hotspot may be ignored in favor of a nearby, higher ranked hotspot.


Another example of a prioritizing factor might be the value or quantity of coupons or offers being marketed by a hotspot. For example, the HAA 115 may not alert a user 101 to a nearby hotspot if a better promotion is being offered by a neighboring business.


If displaying the information on a map view, the HAA 115 may expand or collapse the data displayed to the user depending on the density of the data. For example, if a large number of hotspots are located in a localized area, the HAA 115 may group hotspots together and show the grouping in a single icon or notation. An example of this may be a shopping complex that contains a quantity of hotspots too great to display on a user device. The display may show a shopping complex notation and list the number of hotspots contained at that location or any other manner of representing the group of hotspots. As the user 101 approaches the dense hotspot, the grouped hotspot may expand to show the individual hotspots in that area. For example, if the user 101 is between two shopping malls or between two cities, a single hotspot may be provided for each mall or each city, respectively. Then, as the user approaches one of the malls or one of the cities, the collapsed hotspot for that mall or city expands to show all hotspots (or a specified number of hotspots) at that location.


In certain exemplary embodiments, the HTS 160 applies the extracted data to a machine learning algorithm or another statistical model to determine the most effective ranking system. For example, a machine learning algorithm can be performed on the hotspots generated for one or more users to learn the ranking system that produces results having the highest usage rates. The machine learning algorithm can be updated periodically.


In block 325, the HTS 160 transmits the hotspot zone dimensions, the hotspot identities and locations, and any associated hotspot marketing information to the HAA 115. The HTS 160 may additionally transmit the priority ranking of each of the hotspots for use by the HAA 115.


From block 325, the method 220 proceeds to block 225 with reference to FIG. 2. General


One or more aspects of the invention may comprise a computer program that embodies the functions described and illustrated herein, wherein the computer program is implemented in a computer system that comprises instructions stored in a machine-readable medium and a processor that executes the instructions. However, it should be apparent that there could be many different ways of implementing the invention in computer programming, and the invention should not be construed as limited to any one set of computer program instructions. Further, a skilled programmer would be able to write such a computer program to implement an embodiment of the disclosed invention based on the appended flow charts and associated description in the application text. Therefore, disclosure of a particular set of program code instructions is not considered necessary for an adequate understanding of how to make and use the invention. Further, those skilled in the art will appreciate that one or more aspects of the invention described herein may be performed by hardware, software, or a combination thereof, as may be embodied in one or more computing systems. Moreover, any reference to an act being performed by a computer should not be construed as being performed by a single computer as the act may be performed by more than one computer. The inventive functionality of the invention will be explained in more detail in the following description, read in conjunction with the figures illustrating the program flow.


The exemplary embodiments described herein can be used with computer hardware and software that perform the methods and processing functions described previously. The systems, methods, and procedures described herein can be embodied in a programmable computer, computer-executable software, or digital circuitry. The software can be stored on computer- readable media. For example, computer-readable media can include a floppy disk, RAM, ROM, hard disk, removable media, flash memory, memory stick, optical media, magneto-optical media, CD-ROM, etc. Digital circuitry can include integrated circuits, gate arrays, building block logic, field programmable gate arrays (FPGA), etc.


The exemplary methods and acts described in the embodiments presented previously are illustrative, and, in alternative embodiments, certain acts can be performed in a different order, in parallel with one another, omitted entirely, and/or combined between different exemplary embodiments, and/or certain additional acts can be performed, without departing from the scope and spirit of the invention. Accordingly, such alternative embodiments are included in the inventions described herein.


Although specific embodiments have been described above in detail, the description is merely for purposes of illustration. It should be appreciated, therefore, that many aspects described above are not intended as required or essential elements unless explicitly stated otherwise. Modifications of, and equivalent acts corresponding to, the disclosed aspects of the exemplary embodiments, in addition to those described above, can be made by a person of ordinary skill in the art, having the benefit of the present disclosure, without departing from the spirit and scope of the invention defined in the following claims, the scope of which is to be accorded the broadest interpretation so as to encompass such modifications and equivalent structures.

Claims
  • 1. A method comprising: communicating, by a client network device to a remote network device, a request for place of interest data and first location data for the client network device;receiving, by the client network device, the place of interest data from the remote network device, the place of interest data comprising a plurality of places of interest in a zone defined by the remote network device, the zone based on the first location data of the client network device and having a size based on a density of the plurality of places of interest;selecting one of the plurality of places of interest based on a location history of the client network device; anddisplaying, via a display of the client network device, the one of the plurality of places of interest responsive to second location data of the client network device being within a range of the one of the plurality of places of interest.
  • 2. The method of claim 1, wherein the size of the zone is based on a quantity of data to be received from the remote network device.
  • 3. The method of claim 1, wherein the size of the zone is based on a capacity of a data storage unit of the client network device.
  • 4. The method of claim 1, wherein receiving the place of interest data from the remote network device comprises receiving sets of place of interest data, wherein a frequency of receiving sets of place of interest data is based on a battery life of the client network device.
  • 5. The method of claim 1, wherein the plurality of places of interest are ranked based on a purchase history.
  • 6. The method of claim 1, wherein the plurality of places of interest are ranked based on historical data of website usage.
  • 7. The method of claim 1, wherein the first location data is acquired from an application executing on the client network device.
  • 8. The method of claim 1, wherein displaying the one of the plurality of places of interest comprises displaying the one of the plurality of places of interest in a list.
  • 9. The method of claim 1 further comprising: triggering, via the client network device, a visual alert responsive the second location data of the client network device being within the range of the one of the plurality of places of interest.
  • 10. A non-transitory computer readable storage device storing instructions that, when executed by one or more processors, cause the one or more processors to perform operations comprising: acquiring, from a GPS unit of a client network device, first location data indicative of a location of the client network device;transmitting, by the client network device to a remote network device, a request for place of interest data and the first location data for the client network device;receiving, by the client network device, the place of interest data from the remote network device, the place of interest data comprising a plurality of places of interest in a zone defined by the remote network device, the zone based on the first location data of the client network device and having a size based on a density of the plurality of places of interest;selecting one of the plurality of places of interest based on a location history of the client network device; anddisplaying, via a display of the client network device, the one of the plurality of places of interest responsive to second location data of the client network device being within a range of the one of the plurality of places of interest.
  • 11. The non-transitory computer readable storage device of claim 10, wherein displaying the one of the plurality of places of interest comprises displaying the one of the plurality of places of interest on a map.
  • 12. The non-transitory computer readable storage device of claim 11 storing further instructions that, when executed by one or more processors, cause the one or more processors to perform operations further comprising: displaying, via the display of the client network device, a route to the one of the plurality of places of interest on the map responsive to a user request.
  • 13. The non-transitory computer readable storage device of claim 10, wherein displaying the one of the plurality of places of interest is further responsive to a tap.
  • 14. The non-transitory computer readable storage device of claim 10, wherein displaying the one of the plurality of places of interest is further responsive to a tap.
  • 15. A system comprising: one or more processors; and one or more storage devices storing instructions that, when executed by the one or more processors, cause the one or more processors to perform operations comprising: receiving, from a client network device, first location data indicative of a location of the client network device acquired from a GPS unit of the client network device;accessing place of interest data from a database for an account associated with the client network device;determining a size of a zone based on the place of interest data and the first location data of the client network device;selecting plurality of places of interest from the place of interest data based on the first location data of the client network device and the size of the zone; andtransmitting data for the plurality of places of interest and the zone to the client network device.
  • 16. The system of claim 15, wherein selecting the plurality of places of interest from the place of interest data is further based on a quantity of data to be transmitted to the client network device.
  • 17. The system of claim 15, wherein selecting the plurality of places of interest from the place of interest data is further based on a capacity of a data storage unit of the client network device.
  • 18. The system of claim 15, wherein transmitting data for the plurality of places of interest is based on a frequency of transmitting sets of plurality of places of interest based on a battery life of the client network device.
  • 19. The system of claim 15, wherein selecting the plurality of places of interest is based on a purchase history or a history of website usage.
  • 20. The system of claim 15, wherein the one or more storage devices store instructions that, when executed by the one or more processors, cause the one or more processors to perform operations further comprising: storing the first location data in the database for the account associated with the client network device.
CROSS-REFERENCE TO RELATED PATENT APPLICATIONS

This application claims priority to and is a continuation of U.S. patent application Ser. No. 13/369,182, filed Feb. 8, 2012, herein by which claims priority to and benefit of U.S. Provisional Application 61/586,820, filed Jan. 15, 2012, incorporated herein by reference in their entirety.

Provisional Applications (1)
Number Date Country
61586820 Jan 2012 US
Continuations (1)
Number Date Country
Parent 13369182 Feb 2012 US
Child 14850342 US