The present invention generally relates to systems and methods for reading digital content, and more particularly to systems and methods for transferring digital content between devices.
Electronic devices that permit users to read various forms of electronic publications, such as eBooks, are known. These devices sometimes include a mechanism to permit one user to “lend” or “recommend” an electronic publication by transferring a copy of the publication, or a sample portion, from his/her device to the device of another person, such as a friend or relative. Such a transfer normally involves a series of click through menus and dialogs. This process, while not difficult, may be tedious and time consuming. A need is required for a system of transferring digital content between devices that is more fluid and fun.
The present invention makes it possible for users to recommend and lend electronic publications from one electronic device to another when in proximity to one another. In accordance with one aspect of the present invention, users lay their devices (such as mobile tablets or smart phones) side by side and use a touch screen to “slide” or “swipe” digital content (e.g., via finger swiping of a book cover) from one device to the other. In the event that the digital content (e.g., an eBook) is not authorized for use on the other device, e.g., due to requirements of the content's publisher or because the content has already been lent, the receiving device receives only a sample portion of the book as a recommendation. If the content is authorized for use, the user of the receiving device is presented with various options, such as “Get Sample,” “Buy” and/or “Borrow,” or other options.
In accordance with one embodiment of the present invention, pairing of the devices is accomplished automatically without need for the users to perform any special pairing operation. The pairing of devices can be accomplished, for example, simply by virtue of the two devices being on the same Wi-Fi network or the same ad-hoc local area network established via Wi-Fi Direct or other means, with timing and, optionally, location, of the swipe being used to identify the sending and receiving devices. In one embodiment, the fingers slide onto the receiving device within about a second of leaving the sending device; and the swipe entrance location is directly across from the swipe exit location on opposite edges of the devices. This “location-of-the-swipe” constraint may be implemented, but is not essential to the invention, as the devices may be misaligned, or positioned head-to-side, or in some other physical configuration with respect to each other.
For the purposes of illustrating the present invention, there is shown in the drawings a form which is presently preferred, it being understood however, that the invention is not limited to the precise form shown by the drawing in which:
Referring now to
In another embodiment, contact information is transferred and/or exchanged between devices 130a, 130b after the digital content is transferred. The user and/or friend may be asked whether he/she wishes to add the other to their address book or, alternatively, contact information may be automatically swapped if the user and/or friend change or set appropriate default settings on their respective devices 130a, 130b. If automatic swapping is enabled, it is preferable to display a toast or pop-up window requesting confirmation.
During the dragging operation, devices 130a, 130b communicate either directly (e.g., via Wi-Fi) or through network servers 150 (see
If item 210 is a non-purchased, manually loaded item (e.g., .pdf or Word™ file) a copy of item 210 is transferred to the receiving device 130b similarly to a traditional drag-and-drop copy between devices. If item 210, on the other hand, is a purchased item that can be recommended (i.e., it has associated sample content 220 that can otherwise be retrieved and downloaded by the friend's device) but not lent for any reason, the cover 220 of item 210 will be placed on the home screen of receiving device 130b, and the sample content associated with item 210 will automatically download to the device 130b in the same manner as if the friend chose to download the sample content manually, e.g., via “Get Sample” link from the item's detail page in a “Shop” application. In one embodiment, cover 220 of the sample content is marked with a label “SAMPLE,” as shown in
It should be appreciated that certain types of items 210 may be prohibited from being transferred between devices. For example, in one embodiment, non-purchased, manually loaded items are prohibited from being transferred, although this is not particularly desirable.
As illustrated in
If the user or friend chooses “Borrow” 250, and item 230 is authorized for borrowing (e.g., via an external server in communication with the devices an icon 260 representing the item, e.g., the cover of an eBook, is placed on the home screen of receiving device 130b, for example, via an animation of icon 260 falling into place at the drop location. In one embodiment, icon 260 is marked with a label “BORROWED,” as shown in
If the friend chooses “Get Sample” 245, and item 230 has associated sample content, an icon representing item 210, e.g., the cover of an eBook, is animated to appear to fall into place at the drop location. Similar to that described above, the cover of the sample content may be marked with a label “SAMPLE,” as shown in
It should be appreciated that context menu 240 may display additional options, such as “Purchase,” “Share,” and/or “Add to Wishlist,” and so on. It should also be appreciated that default settings may obviate the need to display certain options or even context menu 240 altogether. For example, the friend may set his/her device 130b to always get sample content if available. In such a case, the above process can proceed automatically as if “Get Sample” 245 had been selected.
If item 230 can neither be lent nor provided as a sample, but can be purchased (e.g., via a “Shop” application), a detail page associated with item 230 is displayed in a “Shop” application, with the friend being given the option to purchase item 230 for download.
If none of the above apply to the item being dragged, or if it is determined that the desired transaction cannot be completed, a toast or pop-up window is displayed informing the user and friend that the drag and drop operating cannot be completed. Optionally and at approximately the same time as the toast or pop-up window is displayed, the cover outline of item 230 may be made to “poof” or disappear.
It may be the case that the default icon size of sending device 130a may be set larger or smaller than the default icon size of receiving device 130b. In such a case, item 230 is dragged to receiving device 130b using the icon size of sending device 130a and animated to the icon size of receiving device 130b after the user's fingers are lifted from receiving device 130b to complete the transfer. For example, if the default icon size of sending device 130a is larger than the default icon size of receiving device 130b, item 230 would remain large throughout the dragging process and shrink after the user's fingers are lifted from receiving device 130b.
Creating this extended “virtual space” between devices may have other uses besides transferring, lending and recommending files and items. For example, once a connection between devices 130a, 130b is established, the following actions may be enabled:
After establishing the connection with exchanged contact/device information, the sender could drag items to an action bubble instead of having to drag between devices 130a, 103b again. This would free users to move devices 130a, 103b anywhere and still share data as described above using the HD between two devices 130a, 103b.
When transferred from device 130a to device 130b, semi-transparent copy 215 appears to get dragged off the edge of device 130a, even though the user's fingers stop generating touch events as soon as they hit the frame of device 130a. To achieve this effect, the device continues moving the dragged copy 215 off the edge of device 130a after copy 215 hits the edge of device 130a and touch events cease, presuming that the user will continue to drag semi-transparent copy 215 to device 130b. If touch events cease while the user's fingers are not near a display edge, and no part of semi-transparent copy 215 is over the screen edge of device 130b, it is assumed that the user intended to cancel the transfer, with semi-transparent copy 215 disappearing thereafter (e.g., via fade, dissolve into dust, poof, etc.).
When the friend's device 103b senses a two finger drag onto its screen, i.e., a two finger drag whose first point of contact is within, say, ½ inch (90 px) of any edge and which is moving away from that edge toward the center, the friend's device 103b initially displays a simple rectangle 217 (see
When the user lifts his/her fingers on receiving device 130b, device 130b needs to quickly determine whether the left is the culmination of a legitimate two-finger transfer from a neighboring device 130a, and work with server/cloud 150 (see
One aspect of the present invention is to detect the user's and friend's intent to transfer digital content between devices 130a, 130b so that devices 130a and 130b may be “paired” for the transfer. This intent may be inferred from any one or a combination of various criteria that must be satisfied before a “pairing” between devices 130a, 130b is effectuated. For example, “pairing” may require that both devices 130a, 103b be logged into to the same ad-hoc local area network or Wi-Fi hotspot 170, i.e., same hotspot SSID or subnet IP address (see
It is possible to pair two devices that are close to one another but not on the same hotspot. A clever client or server based algorithm can infer that two devices are in the same area if they “see” substantially the same set of available hotspots, optionally, at substantially the same signal strengths. If two devices are determined to be in the same vicinity, an intent to transfer content can be inferred from a two-finger slide that enters one of the devices within a short period of time (such as within 1 sec) of a two-finger slide exiting the other device. As noted above, additional constraints may be applied, such as observing the positions along the device edges where slides exit and enter, and ensuring that the exit from one device at least approximately abuts the entrance of the other device. It should be appreciated that pairing devices on different hotspots is more complex and more likely to introduce high latency, compared to pairing devices on the same hotspot. For this reason, certain embodiments focus on supporting transfers between devices that are already known to be on the same hotspot or on the same ad-hoc local area network established via Wi-Fi direct or other means.
In another implementation for pairing the two devices 130a, 103b, both devices 130a, 103b are on a screen for a lending application in their libraries, so both devices are “listening” for lends.
It should be appreciated that peer-to-peer transfer of the content is not necessary because the system need only know which item is being lent or recommended. In such an embodiment, a server/cloud 150 (see
Device Connection Options.
To implement slide-to-lend transfers, the two devices 130a, 103b should be connected in close proximity. Some potential ways to implement this connection are as follows.
1. Multicast Packets. When two devices 130a, 103b are connected via Wi-Fi 170 to the same access point, the most likely case, the sending device 130a may broadcast multicast UDP packets to all devices on the local subnet. The receiving device 130b must be listening for these packets to make the connection. The advantage of this approach is that it is local and fast. The disadvantage is that not all routers permit multicasting, which could cause user frustration.
2. Cloud. This method for connecting two devices 130a, 103b relies on the cloud, remote servers 150, to connect the devices 130a, 103b. Both devices 130a, 103b are connected to the same Wi-Fi access point 170 (See
3. Wi-Fi Ad Hoc. This approach creates an ad hoc Wi-Fi network between devices 130a, 103b. Such an approach advantageously creates a 100% reliable connection between proximate devices 130a, 130b without relying on Wi-Fi access point 170 or server/cloud 150. On the other hand, this approach severs the connection to the server/cloud 150 and may increase the time required to establish a connection between devices 130a, 103b, thereby leading to a degraded user experience.
4. Wi-Fi Direct. Wi-Fi Direct allows devices 130a, 130h to establish an ad hoc network while simultaneously maintaining an existing connection to the Internet 140. In this manner, the content transfer process would not need to wait for an ad hoc network to be established. The network may be kept enabled at all times, or only when the user is both accessing his/her home screen and conducting two-finger slides of items. This approach is advantageous because it does not rely on a connection to Wi-Fi access point 170, the Internet 140, a multicast or server/cloud 150, and does not require closing an Internet connection, to the extent one exists.
Collisions or interceptions. A swipe on to two different potential “receiving” devices within the same area (e.g., the same hotspot) can potentially occur after the swipe off the sending device (or vice-versa) in that area. This may occur either accidentally (called a “collision”) or intentionally, such as when a third party attempts to “intercept” a swipe between two other devices. The system avoids collisions and interceptions by simply requiring that only one sending device and one receiving device are engaged in a transfer operation within the same area. To the extent additional sending and/or receiving devices exist in the area, the system can simply ignore or cancel the transaction. This would require that the transfer process be reinitiated.
Associated with the user's 105 account is the user's 105 digital locker 120a located on the server/cloud 150. As further described below, in the preferred embodiment of the present invention, digital locker 120a contains links to copies of digital content 125 previously purchased (or otherwise legally acquired) by user 105.
Indicia of rights to all copies of digital content 125 owned by user 105, including digital content 125, is stored by reference in digital locker 120a. Digital locker 120a is a remote online repository that is uniquely associated with the user's 105 account. As appreciated by those skilled in the art, the actual copies of the digital content 125 are not necessarily stored in the user's locker 120a, but rather the locker 120a stores an indication of the rights of the user to the particular content 125 and a link or other reference to the actual digital content 125. Typically, the actual copy of the digital content 125 is stored in another mass storage (not shown). The digital lockers 120 of all of the users 105, 109 who have purchased a copy of a particular digital content 125 would point to this copy in mass storage.
Of course, back up copies of all digital content 125 are maintained for disaster recovery purposes. Although only one example of digital content 125 is illustrated in this Figure, it is appreciated that the lending server/cloud 150 can contain millions of files 125 containing digital content. It is also contemplated that the server/cloud 150 can actually be comprised of several servers with access to a plurality of storage devices containing digital content 125. As further appreciated by those skilled in the art, in conventional licensing programs, the user does not own the actual copy of the digital content, but has a license to use it. Hereinafter, if reference is made to “owning” the digital content, it is understood what is meant is the license or right to use the content.
Also contained in the user's digital locker 120a is her contacts list. In a preferred embodiment, the user's contact list will also indicate if the contact is also an authorized (registered) user of the system 100 with his or her own account on server/cloud 150. This information can be use by Slide Between Devices module 160 to swap contact information between users 105, 109 as described above.
User 105 can access his or her digital locker 120a using a local device 130a. Local device 130a is an electronic device such as a personal computer, an e-book reader, a smart phone or other electronic device that the user 105 can use to access the server/cloud 150. In a preferred embodiment, the local device has been previously associated, registered, with the user's 105 account using user's 105 account credentials. Local device 130a provides the capability for user 105 to download user's 105 copy of digital content 125 via his or her digital locker 120a. After digital content 125 is downloaded to local device 130a, user 105 can engage with the downloaded content locally, e.g., read the book, listen to the music or watch the video.
In a preferred embodiment, local device 130a includes a non-browser based device interface that allows user 105 to initiate the discussion functionality of system 100 in a non-browser environment. Through the device interface, the user 105 is automatically connected to the server/cloud 150 in a non-browser based environment. This connection to the server/cloud 150 is a secure interface and can be through the telephone network 145, typically a cellular network for mobile devices. If user 105 is accessing his or her digital locker 120a using the Internet 140, local device 130a also includes a web account interface. Web account interface provides user 105 with browser-based access to his or her account and digital locker 120a over the Internet 140.
User 109 is also an authorized user of system 100. As with user 105, user 109 has an account with lending server/cloud 150, which authorizes user 109 to use lending system 100. As appreciated by those skilled in the art, the number of users 105, 109 that employ the present invention at the same time is only limited by the scalability of server/cloud 150. As with user 105, user 109 can access his or her digital locker 120b using her local device 130b. In a preferred embodiment, local device 130b is a device that user 109 has previously associated, registered, with his or her account using user's 109 account credentials. Local device 130h allows user 109 to download copies of his digital content 125 from digital locker 120b. User 109 can engage with downloaded digital content 125 locally on local device 130b.
The Slide Between Devices module 160 performs the “cloud” operations discussed herein. Further, the Slide Between Devices module 160 coordinates with the other components of server/cloud 150 to facilitate the loan or recommendation of digital content as described in co-pending application U.S. Ser. No. 13/154,350 filed Jun. 6, 2011, the entirety of which is incorporated herein by reference.
Devices 130a and 130b can further be connected via Wi-Fi AP 170, as described above.
Electronic device 130 can include any suitable type of electronic device. For example, electronic device 130 can include a portable electronic device that the user may hold in his or her hand, such as a digital media player, a personal e-mail device, a personal data assistant (“PDA”), a cellular telephone, a handheld gaming device, a tablet device or an eBook reader. As another example, electronic device 130 can include a larger portable electronic device, such as a laptop computer. As yet another example, electronic device 130 can include a substantially fixed electronic device, such as a desktop computer.
Control circuitry 500 can include any processing circuitry or processor operative to control the operations and performance of electronic device 130. For example, control circuitry 500 can be used to run operating system applications, firmware applications, media playback applications, media editing applications, or any other application. Control circuitry 500 can drive the display 550 and process inputs received from a user interface, e.g., the display 550 if it is a touch screen.
Orientation sensing component 505 include orientation hardware such as, but not limited to, an accelerometer or a gyroscopic device and the software operable to communicate the sensed orientation to the control circuitry 500. The orientation sensing component 505 is coupled to control circuitry 500 that controls the various input and output to and from the other various components. The orientation sensing component 505 is configured to sense the current orientation of the portable mobile device 130 as a whole. The orientation data is then fed to the control circuitry 500 which control an orientation sensing application. The orientation sensing application controls the graphical user interface (GUI), which drives the display 550 to present the GUI for the desired mode.
Storage 530 can include, for example, one or more computer readable storage mediums including a hard-drive, solid state drive, flash memory, permanent memory such as ROM, magnetic, optical, semiconductor, paper, or any other suitable type of storage component, or any combination thereof. Storage 510 can store, for example, media content, e.g., eBooks, music and video files, application data, e.g., software for implementing functions on electronic device 130, firmware, user preference information data, e.g., content preferences, authentication information, e.g., libraries of data associated with authorized users, transaction information data, e.g., information such as credit card information, wireless connection information data, e.g., information that can enable electronic device 130 to establish a wireless connection, subscription information data, e.g., information that keeps track of podcasts or television shows or other media a user subscribes to, contact information data, e.g., telephone numbers and email addresses, calendar information data, and any other suitable data or any combination thereof. The instructions for implementing the functions of the present invention may, as non-limiting examples, comprise software and/or scripts stored in the computer-readable media 530.
Memory 520 can include cache memory, semi-permanent memory such as RAM, and/or one or more different types of memory used for temporarily storing data. In some embodiments, memory 520 can also be used for storing data used to operate electronic device applications, or any other type of data that can be stored in storage 510. In some embodiments, memory 520 and storage 510 can be combined as a single storage medium.
I/O circuitry 530 can be operative to convert, and encode/decode, if necessary analog signals and other signals into digital data. In some embodiments, I/O circuitry 530 can also convert digital data into any other type of signal, and vice-versa. For example, I/O circuitry 530 can receive and convert physical contact inputs, e.g., from a multi-touch screen, i.e., display 550, physical movements, e.g., from a mouse or sensor, analog audio signals, e.g., from a microphone, or any other input. The digital data can be provided to and received from control circuitry 500, storage 510, and memory 520, or any other component of electronic device 130. Although I/O circuitry 530 is illustrated in this Figure as a single component of electronic device 130, several instances of I/O circuitry 530 can be included in electronic device 130.
Electronic device 130 can include any suitable interface or component for allowing a user to provide inputs to I/O circuitry 530. For example, electronic device 130 can include any suitable input mechanism, such as a button, keypad, dial, a click wheel, or a touch screen, display 550. In some embodiments, electronic device 130 can include a capacitive sensing mechanism, or a multi-touch capacitive sensing mechanism.
In some embodiments, electronic device 130 can include specialized output circuitry associated with output devices such as, for example, one or more audio outputs. The audio output can include one or more speakers, e.g., mono or stereo speakers, built into electronic device 130, or an audio component that is remotely coupled to electronic device 130, e.g., a headset, headphones or earbuds that can be coupled to device 130 with a wire or wirelessly.
Display 550 includes the display and display circuitry for providing a display visible to the user. For example, the display circuitry can include a screen, e.g., an LCD screen, that is incorporated in electronics device 130. In some embodiments, the display circuitry can include a coder/decoder (Codec) to convert digital media data into analog signals. For example, the display circuitry or other appropriate circuitry within electronic device can include video Codecs, audio Codecs, or any other suitable type of Codec.
The display circuitry also can include display driver circuitry, circuitry for driving display drivers, or both. The display circuitry can be operative to display content, e.g., media playback information, application screens for applications implemented on the electronic device 130, information regarding ongoing communications operations, information regarding incoming communications requests, or device operation screens, under the direction of control circuitry 500. Alternatively, the display circuitry can be operative to provide instructions to a remote display.
Communications circuitry 540 can include any suitable communications circuitry operative to connect to a communications network and to transmit communications, e.g., data from electronic device 130 to other devices within the communications network. Communications circuitry 540 can be operative to interface with the communications network using any suitable communications protocol such as, for example, Wi-H, e.g., a 802.11 protocol, Bluetooth, radio frequency systems, e.g., 900 MHz, 1.4 GHz, and 5.6 GHz communication systems, infrared, GSM, GSM plus EDGE, CDMA, quadband, and other cellular protocols, VOW, or any other suitable protocol.
Electronic device 130 can include one more instances of communications circuitry 540 for simultaneously performing several communications operations using different communications networks, although only one is shown in this Figure to avoid overcomplicating the drawing. For example, electronic device 130 can include a first instance of communications circuitry 540 for communicating over a cellular network, and a second instance of communications circuitry 540 for communicating over Wi-Fi or using Bluetooth. In some embodiments, the same instance of communications circuitry 540 can be operative to provide for communications over several communications networks.
In some embodiments, electronic device 130 can be coupled to a host device such as digital content control server/cloud 150 for data transfers, synching the communications device, software or firmware updates, providing performance information to a remote source, e.g., providing riding characteristics to a remote server, or performing any other suitable operation that can require electronic device 130 to be coupled to a host device. Several electronic devices 130 can be coupled to a single host device using the host device as a server. Alternatively or additionally, electronic device 130 can be coupled to several host devices, e.g., for each of the plurality of the host devices to serve as a backup for data stored in electronic device 130.
Although the present invention has been described in relation to particular embodiments thereof, many other variations and other uses will be apparent to those skilled in the art. It is preferred, therefore, that the present invention be limited not by the specific disclosure herein, but only by the gist and scope of the disclosure.
Number | Date | Country | |
---|---|---|---|
61558875 | Nov 2011 | US |