The present disclosure relates to data sharing, including sharing contact information, and determining potential candidates for data sharing between devices based on relative proximity of the devices.
Exchange of personal and professional contact information with another via business cards is on the decline, while digital contact information exchange is now trending. Social media tools are focused around an online forum rather than live meetings. There is a need for exchanging digital contact information immediately or upon request, such as in an impromptu situation or event, and for controlling future access to the exchanged information.
A first aspect is a method for exchanging user data. The method includes, in response to a user enabling an interface component of a device of the user, commencing identifying potential nearby contacts; displaying a subset of the potential nearby contacts while the interface component is enabled; continuing the identifying of the potential nearby contacts while the interface component is enabled; in response to the user disabling the interface component, stopping identifying additional potential nearby contacts; receiving a selection of a potential nearby contact of the displayed subset of the potential nearby contacts; in response to receiving the selection of the potential nearby contact, sending a request to the potential nearby contact to become connected with the potential nearby contact; and in response to the potential nearby contact accepting the request, setting the user as a contact of the potential nearby contact.
A second aspect is a device for exchanging user data between a first user and a second user. The device includes a memory and a processor. The processor is configured to execute instructions stored in the memory to receive a scan code corresponding to the second user; and transmit, to a server, a request to connect the first user with the second user.
A third aspect is a system includes a first user device of a first user that includes a first processor and a second user device of a second user that includes a second processor. The first processor is configured to display a scan code corresponding to the first user of a display of the first user; display an indication of a request from the second user; and receive, from the first user, a response to the request, wherein the response indicates whether to accept the request or to reject the request. The second processor is configured to receive from a scan code reader of the second user device an image of the scan code; and responsive to receiving the scan code, transmit the request to connect the second user with the first user.
A fourth aspect is a method for exchanging user data between a first user and a second user. The method includes detecting, using a first user device of a first user, a proximity of a second user device of a second user; identifying, on the first user device, the second user as a potential contact for the first user; and responsive to an action of the first user, initiating a request to connect the first user with the second user.
The invention is best understood from the following detailed description when read in conjunction with the accompanying drawings. It is emphasized that, according to common practice, the various features of the drawings are not to-scale. On the contrary, the dimensions of the various features are arbitrarily expanded or reduced for clarity.
Various aspects of this disclosure are now described with reference to the drawings. In the following description, numerous specific details are set forth in order to provide a thorough understanding of one or more aspects. It should be understood, however, that certain aspects of this disclosure may be practiced without these specific details, or with other methods, components, materials, etc. In other instances, well-known structures and devices are shown in block diagram form to facilitate describing one or more aspects.
The present disclosure presents methods and apparatuses for detecting the proximity of contacts relative to a user and sharing contact information between the user and one or more detected contacts. A user of the disclosed method and apparatus, including without limitation computer readable instructions executable by the processing unit of the electronic device present disclosure (collectively, the “application”; noting, however, that said term may also include further embodiments as may hereinafter be described or referenced), may receive contact and other information and data (collectively, “user data”) from detected contacts (i.e., other users) and send their own user data thereto based in part on the types of information each user elects to share, the nature of the relationship between the users, and the conditions under which any user data may be shared. Generally, each user may receive user data from and transmit user data to other users, for example, by way of a server in communication with each user device, thereby resulting in a real-time exchange of user data, subject to any limitations as may be imposed by each user.
As used herein, the term “user” includes individuals and entities using the application, for example, at least based on the existence of an account profile belonging thereto. As used in the singular form, “user” may refer to a human user by example. As used in the plural form, “users” may refer to one or more potential contacts and/or registered contacts. Notwithstanding the foregoing, it will be apparent that “user” may include various other embodiments as may hereinafter be described or referenced.
A user device 100 for detecting contact proximity and sharing contact information may include a processing unit 110, a memory unit 120, a location component 130, a communication component 140, a user interface unit 150, or a combination thereof. The user device 100 may be an electronic device, which may be, without limitation, a smartphone, personal digital assistant, tablet computer, laptop computer, desktop computer or other Internet-connectable device.
The processor 110 may be one or more various computer processors used to process data and perform computing tasks including without limitation a central processing unit (CPU) 112, and/or a graphical processing unit (GPU) 114 as shown in
The storage memory 120 may be one or more various volatile and nonvolatile memory types including without limitation random access memory, read only memory, flash memory or other removable/non-removable storage media. The storage memory 120 may include a system memory module that may store executable computer instructions that, when executed by the processor 110, perform various user device functionalities including those described herein. The storage memory 120 may store data, including user account information or contact information, entered by the user via user interface unit 150 or received from the communication component 140.
The location component 130 may include, for example, a global positioning system module or geolocation module, which, based on its configuration, may be in communication with satellite or other external systems for tracking the location of an electronic device. In some embodiments, the positioning data received by the location component 130 may be one or more of a set of coordinates and a common address (e.g., a street address along with corresponding city, state/province/country information). The location component 130 may identify a location of the user device 100 using positioning data. The communication component 140 may send and receive electronic data including, for example, user data. The user interface unit 150 may maintain the user's account profile and user data and the user data of other users, as well as receiving user commands to be processed.
The communication component 140 may include, for example, a modem or other hardware module or adapter for connecting the electronic device to a network, such as an intranet, local network, or the Internet, either through a physical connection (e.g., Ethernet) or wireless connection (e.g., Wi-Fi). In some embodiments, the communication component may connect the user device to, and thereafter communicate with, a server and/or one or more other user devices.
The user interface unit 150 may include one or more units that may register or receive input from a user or present outputs to the user, such as a display, touch interface, a proximity sensitive interface, a light receiving/emitting unit, sound receiving/emitting unit, a wired/wireless unit, or other units. In some embodiments, the user interface unit 150 may include a display, one or more tactile elements (e.g., buttons or virtual touch screen buttons), lights (e.g., LED), speakers, or other user interface elements. The user interface unit 150 may receive user input and provide information to a user related to operation of the user device 100. The interface unit 150 may include, for example, part of a software application installed on and executed by the processor 110 and configured to receive and store user data, contact data and other information stored in the memory 120.
In some embodiments, the user interface unit 150 may include a display screen, such as a touch screen, for displaying content and receiving user commands to be processed. The user interface unit 150 may be supported by one or more input configurations including without limitation a keyboard and/or mouse configuration, a touchscreen configuration, and a microphone and speaker configuration. In some embodiments, the user interface unit 150 g may include user-selected customization features for creating and maintaining user data in an account profile. For example, the user interface unit 150 may include graphical features to enable the user to establish settings data, which may include various settings for modifying or limiting certain aspects of the software application.
The user data, the contact data, the settings data, or a combination thereof, may be stored within the storage memory 120 of the user device 100, within non-transient memory contained within the server, or a combination of both. For example, data associated with the user account profile may be input using the user interface unit 150, which may be immediately stored in storage memory 120 of the user device 100, and may be transmitted via the communication component 140 to a network server for storage in the network database within the server memory. The user data, contact data, and settings data may be communicated to the server periodically or in response to data changes, for example, to update contact data registered with various users or record select user preferences.
The account profile of the user may include user data of the user, which is viewable at least in part by certain other users. For example, “registered contacts” referred herein as network users with whom user data is being shared with the user, may view user data of the user. In some embodiments, the account profile may comprise various graphical features. For example, a picture (which may include without limitation a photograph, a computer generated image, a solid color, or a patterned image) may be uploaded to use as the background for the user account profile, or a picture may be retrieved from a library provided by the application or server. In some embodiments, the various media files, such as video, audio and picture files, may be uploaded to the account profile and made available for viewing by other users. For example, an entity user may upload commercials or other marketing materials to the account profile to promote goods and services to potential customers.
The user data may include information relative to an account profile of a user and may comprise name, title, company, availability status, account picture, phone and mobile numbers, mailing addresses, email addresses, facsimile numbers, social media links, websites, birthday, anniversary, and/or other information associated with the user. The user data may be received from a user interface. In some embodiments, user data may further include present and past location data for the user. The user data may be organized into one or more profiles (e.g., a work profile comprising the user's business contact information and a home profile comprising personal contact information), to permit the user to conveniently elect for only certain profiles to be publicly viewable, and/or to distinguish professional and personal user data for presentation to other users.
The contact data may include user data relative to registered contacts, which may be viewable by the user, for example, as a contact list accessible within the application. In some embodiments, the registration of further contact data or modification of existing contact data for a registered contact may be automatic according to user-based configuration by the user. In some embodiments, the registration of further contact data or modification of existing contact data for a registered contact may be received from a user interface in response to user entry. As an example of automatic modification, a registered contact of the user may elect to no longer share certain contact data with the user, permissions for the contact data relative to the user may be changed by the registered contact, thereby causing that contact data to no longer be viewable by the user. The contact data may be organized into one or more profiles as set by the corresponding user.
The settings data may include settings configured by the user device in accordance with selections by the user. In some embodiments, the settings data may be input to the user device via a user interface, such as the user interface unit 150 of
The proximity range setting may indicate a particular proximity range relative to the user device location, within which searching and detecting of other users may be executed, such as searching and detecting potential contacts for the user within a two mile radius of the user's present location. In some embodiments, a network server may receive the proximity range setting from the user device, and may identify other users concurrently located within proximity of the user corresponding to the proximity range setting. In some embodiments, the user device may include a location detection function that uses peer-to-peer signals with a user device of another user located within a proximity of the user as defined by the proximity range setting. The proximity range setting may be fixed and unchangeable, or may be adjustable by the user.
The detection preferences setting may be defined by the user and may identify other users individually or a classification of users as potential contacts to be detected within the proximity range. For example, the detection preferences setting may be set to allow all users to be detected, or it may instead allow only certain selected users (e.g., entities that are restaurants, users identified by a first name, age, or gender, or other criteria) to be detected.
The user data setting may indicate the degree to which the user data (or specific portions thereof) is viewable by other users. In some embodiments, the user may define all or select portions of the user data as being public user data (i.e., automatically viewable by other users) or private user data (i.e., only viewable by other users upon the user granting permission therefor). The user may modify the user data setting from an initial setting. For example, the user data setting for a portion of the user data may be changed from public user data to private user data, and vice versa.
Based on the settings data, the server may detect other users located within the defined proximity range. Users who have not previously shared user data with the user, as well as users who have, but who no longer are sharing user data with the user, may be defined as “potential contacts.” Users who are currently sharing user data with the user may be defined as “registered contacts.” In some embodiments, upon detecting a potential contact, the user may send an exchange request to the potential contact by electing to share all user data, some user data, or no user data with the potential contact, provided that user data defined as public may automatically be shared upon initiating the exchange request. Upon the potential contact and the user each agreeing to share user data with one another, the user and the potential contact each become registered contacts to one another, and user data of the potential contact may be shared with the user as contact data and vice versa. In some embodiments, the user and a potential contact or registered contact may elect to enter into a private chat wherein they may communicate messages to each other.
The user device 202 may communicate with the network entities via communication link 204, and may access the network server 232 via a network or internet connection 234. The one or more other user devices 212 may be located within the proximity range as defined by the proximity range setting. In some embodiments, the user device 202 may communicate with the network server 232 to set up the account profile of the user and to upload the settings data onto the network server 232. The network server may detect the one or more user devices 212 as being associated with potential contacts for the user of user device 202 in response to an action by the user. For example, the user may open or start an application on the user device 202, which may automatically send a signal on communication link 204 to the access point 222 and forwarded to the network server 232 over the internet or network 234. The signal may include the location data and/or the settings data of the user device 202. Meanwhile, one or more other users registered with the network on associated user devices 212 may have communicated respective location data to the network server on communication link 214 via the access point 222 and the network 234. Based on the location data and/or settings data received from the user devices 202/212, the network server 232 may identify one or more user devices 212 as being located within the proximity range as set by the user device 202, and as such, are identified as potential contacts for the user of user device 202. In some embodiments, the user devices 202/212 may exchange location data directly, such as through a peer-to-peer communication link 224, which may then be transmitted to the network server 232.
In some embodiments, the user device 202 may receive an indication from the network server 232 of user devices 212 associated with potential contacts, as identified by the network server 232. The user device 202 may display the potential contacts on a user interface, from which a potential contact may be selected for exchanging user data such as contact information. The user device 202 may send the potential contact selection to the network server via the communication link 204. In response to the potential contact selection, the network server 232 may send a request to the user device 212 of the potential contact for exchanging contact information with the user of user device 202. If the potential contact agrees to exchange data with the user of user device 202, the data sharing may be transmitted via the network over communication links 204/214, or the data sharing may be transmitted directly via link 224. In some embodiments, the user and the new contact may commence a chat session via the network over communication links 204/214, or the chat session may be transmitted directly via peer-to-peer link 224. For example, a user sharing application may be activated on both the user device 202 and the device 212 of the new contact, which enables a chat session to be initiated by either the user or the new contact.
In some embodiments, the method 300 may be implemented as a computer readable medium that stores instructions executable by processor. In some embodiments, the instructions may be stored in a memory, such as a memory in the network server 232 of
In some embodiments, the user data for registered users may be identified by the network at 302. For example, the user profile of each user includes the contact information of the user, which is recorded during registration and stored by the network server 232. Any updates to the contact information may be based on user input at the user device, and may be recorded and stored by the network server 232.
In some embodiments, the location of the user device 202 may be determined at 304. As detection of potential contacts is dependent upon location data of the user, the network server 232 regularly identifies the location of the user device 202 based on location data determined by the location component and transmitted by the communication component of the user device, such as location component 130 and communication component 140 of
In some embodiments, a potential contact located within the selected proximity range may be identified at 306. The network server 232 may maintain records of location data for all user devices in communication with the network server 232. The location of other user devices 212 may be computed, for example, by calculating the distance between the user device 202 and other user devices 212. In the event other user devices 212 are determined to be within the proximity range defined by the settings data, subject to any detection preferences defined by the user, such other user devices 212 may be detected by the network server 232 based on the location data. In some embodiments, the network server 232 may notify the user that potential contacts are nearby. For example, the user device 202 may receive the notification of potential contacts, and execute a visual display for identifying the locations of potential contacts, such as by visually denoting the locations on a map. The user may then select one or more detected users to share user data with, subject to each user's user data settings.
In some embodiments, the network server may generate and send messages between the user and the potential contact related to data sharing at 308. For example, in response to the user's selection of a potential contact, a request message may be sent from the user device 202 indicating a request for an invitation message to be sent to the potential contact. The request message may include a permission setting indicating which user data and/or which user data profile of the user is selected to be shared with the potential contact. Responsive to receiving the request message, the network server 232 may generate and deliver the invitation message to the device 212 of the potential contact. A response message may be sent from the device 212 of the potential contact indicating acceptance or denial of the invitation. Responsive to receiving the response message, the network server 232 may generate and deliver a response message to the user device 202.
In some embodiments, the user device 202 may send the exchange request (e.g., via an electronic message) to the potential contact, via the network server 232, which the potential contact may accept, for example, by similarly selecting to share user data or entering into a chat conversation with the user. The potential contact may decline the exchange request, for example, by refusing to share any user data or refusing to enter into the chat conversation.
In some embodiments, the user device 202 may exchange data with the device 212 of the selected potential contact at 310. The user and potential contact may each select which user data is to be shared. For example, the data exchange may be limited based on permission settings elected by the user and/or the potential contact. In response to the network server 232 receiving a message from the device 212 of the potential contact identifying the potential contact's user data selected to be shared with the user, such as according to a permission setting, the network server 232 may send the acceptance response message to the user device 202. The network server 232 may designate the user and the potential contact as registered contacts to each other, and the user data selected to be shared by the user and the potential contact may be registered as contact data respectively. The network server 232 may execute the data sharing by sending user data of the user, such as contact information, to the device 212 of the registered contact, and by sending user data of the potential contact, such as contact information, to the user device 202.
In some embodiments, the user activated contact detection of
In some embodiments, the application interface display 612 may be displayed in response to the request to exchange data, and may include selectable user data of the user, from which the user may select which user data of one or more user profiles to share with the potential contact. For example, the application interface display 612 may provide options for the user to share all data via icon 613, selectively share only certain user data (e.g., only certain profiles or portions thereof), or share no user data and instead request to enter into a chat conversation with the potential contact, by selection of chat only icon 614 for example.
In some embodiments, location region 616 of the application interface display 612 may indicate a location for the user device when the user device associated with potential contact identification 606 was detected by the network and identified to the user device 202.
In some embodiments, the application interface display 622 may indicate the user selection for user data for the data exchange. For example, a share all icon 624 may be responsive to user input, such as by touch screen tapping the icon 624, and all user data of the display may be visually altered for feedback display, such as shown by a highlighted region 626, to indicate confirmation by the user device 202 for the user selection. In some embodiments, the application interface display 622 may provide an interface for the user to accept the selected data sharing information, such as by touch screen tapping the accept icon 628. In response to the user input at the accept icon 628, the user device 202 may execute a data sharing request to the network server 232.
In some embodiments, the user device 202 may provide global user data changes by the user. For example, an application interface display may be presented to the user on the user interface unit 150 which shows the user data for all user profiles of the user as recorded on the network server 232. The user data profiles may be edited at any time by the user, allowing all registered contacts to have access to current user data once the user data is edited by the user and saved to the network server 232. Unlike with one-off transmissions of contact information, or exchanging of business cards, the user need not redistribute updated contact information since the update may be global via the central repository in the network server 232.
In some implementations, an account profile can be set to be a public profile or a private profile. In some implementations, if the account profile of the potential contact is a pubic account, then receiving, from the potential contact, the acceptance of the communication, can be automatic. That is, the potential contact need not explicitly accept the communication. Rather, the acceptance can be automatically generated on behalf of the potential contact. In an example, a network server, such as the network server 232 of
In some implementations, the user can cancel a data exchange request. That is, the user can revoke the data exchange request with a potential contact. The request can be cancelled before it is accepted by the potential contact. As such, a cancelled request is removed from the pending exchange requests list, as described with respect to pending exchange icon 906 and the application interface display 912 of
In some implementations, the user can modify a data exchange request. For example, and referring to
Reference is now made again to the method 300 of
For example, a user can leave a contact exchange request for a potential contact at a geolocation. The geolocation can be an address, a landmark name, a cross-roads, a set of coordinates, a GPS location, or any other indication that can be converted to, or have associated, a geolocation. That is, the user can indicate an intention to have a communication sent to the user to initiate data exchange, as described with respect to 308 of
In an illustrative, but non-limiting, example, a home owner may be aware that a service provider is going door-to-door within the home owner's neighborhood soliciting business. The home owner is interested in the service. However, as the homeowner cannot be home 100% of the time to wait for the service provider, the home owner (i.e., the user) can leave a data exchange request at her home location. If/when the service provider visits the location (i.e., the home) of the homeowner, the service provider receives the data exchange request. In this scenario, the service provider is the potential contact.
An application interface display that is similar to the application interface display 922 of
Accordingly, identifying the potential contact at 306 can include receiving, from the potential contact, a first location; and identifying the potential contact in a case that a second location of the user device matches the first location. In an example, the first location is an address (such as a postal address), and the second location is a geolocation that is proximate the first location. In an example, the first location can be converted to a geolocation. In an example, the second location matches the first location in a case that the first location and the second location are within a threshold distance. In an example, the threshold distance can be 10, 20, 30 feet, or some other distance. The threshold distance can be characterized by being a relatively small distance. In another example, the first location is a first geolocation and the second location is a second geolocation that is within a predefined distance of the first geolocation.
Another scenario according to implementations of this disclosure can be summarized as “if someone comes to a location of my choosing, identify me to that someone as a potential contact, even if I am (i.e., even if my device is) not actually at the location.” Said another way, a potential contact can place a marker based on an affiliated geolocation or coordinate for detection and exchange by a user.
In an illustrative, but non-limiting, example, a business person has a business address of address 555 N Main Street, Ann Arbor, Mich. The business person is regularly visited by sales representatives. The business person finds value in the interactions with some of the sales representatives and would like to know who visits him when he is out of the office. When the business person is out of office, he can place a marker at that address (or, equivalently, the geolocation of the address) for anyone to detect and exchange information with him. As such, for example, when a sales representative is at the business address, and the sales representative performs, using a user device, an operation (such as via one or more user interfaces that are similar to those described with respect to
Accordingly, and referring to
Accordingly, another method for data sharing between devices in a network can include receiving, from a potential contact (e.g., the business person in the above scenario), a first location (e.g., the geolocation, the postal address, cross roads, etc., of the business address of the business person); and, in a case that a second location of a user device of a user (e.g., the sales representative) matching the first location, identifying, for the user, the potential contact, and receiving, from the user device, a request for the user to become a contact with the potential contact. The request can include a permission setting, which indicates whether a subset of user data of the user can be viewed by the potential contact. The method can also include sending, based on the request, a communication to the potential contact to initiate a data exchange; and, in response to receiving an acceptance of the communication, setting the user as a contact of the potential contact and setting the potential contact as a contact of the user. The subset of the user data is viewable to the potential contact in accordance with the permission.
While the invention has been described in connection with certain embodiments, it is to be understood that the invention is not to be limited to the disclosed embodiments but, on the contrary, is intended to cover various modifications and equivalent arrangements included within the scope of the appended claims, which scope is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures as is permitted under the law.
This application is a continuation of U.S. application Ser. No. 16/212,902, filed Dec. 7, 2018, which is a continuation-in-part of U.S. application Ser. No. 15/217,424, filed Jul. 22, 2016, which claims the benefit of U.S. Provisional Application Nos. 62/195,534, filed Jul. 22, 2015, and 62/234,246, filed Sep. 29, 2015, the disclosures of which are incorporated herein by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
62234246 | Sep 2015 | US | |
62195534 | Jul 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16212902 | Dec 2018 | US |
Child | 17315702 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15217424 | Jul 2016 | US |
Child | 16212902 | US |