1. Field
The field relates to managing device settings and content.
2. Related Art
Mobile phones, tablet computers, netbooks, and television set-top boxes are different types of electronic devices that allow the use of different types of content. Each of these types of devices may hold different types of content items and have different settings and capabilities.
As the broad use of different types of content devices continues to increase, there is an increasing need for an improved, integrated approach to adding, removing and managing content items and configuration settings on different devices.
Embodiments described herein relate to a method, apparatus and computer program product for manipulating device content using a network-based application. According to an embodiment, a method of modifying, with a network-based application, a content item on a device is provided. The method may include receiving over a network, at a server, information describing the content item from the device. Next, the information describing the content item is sent to a client computer and, at the client computer, the content item is presented to a user with the network-based application by displaying a graphical depiction of the device, the graphical depiction showing the content item as it would appear on a display of the device. A request is then received for a modification of the content item from the user using the network-based application. Finally, the request for the modification is sent to the device over the network.
The accompanying drawings, which are incorporated in and constitute part of the specification, illustrate embodiments and, together with the general description given above and the detailed description of embodiments given below, serve to explain the principles of the present invention. In the drawings:
The following detailed description refers to the accompanying drawings that illustrate exemplary embodiments. Other embodiments are possible, and modifications may be made to the embodiments within the spirit and scope of the invention. Therefore, the detailed description is not meant to limit the invention. Rather, the scope of the invention is defined by the appended claims.
Features and advantages of the invention are set forth in the description that follows, and in part are apparent from the description, or may be learned by practice of the invention. The advantages of the invention are realized and attained by the structure and particularly pointed out in the written description and claims hereof as well as the appended drawings. The following detailed description is exemplary and explanatory and is intended to provide further explanation of the invention as claimed.
The embodiment(s) described and references in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” etc., indicate that the embodiment(s) described may include a particular feature, structure, or characteristic. However, every embodiment may not necessarily include the particular feature, structure or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. When a particular feature, structure or characteristic is described in connection with an embodiment, it is understood that it is within the knowledge of one skilled in the art to effect such feature, structure, or characteristic in connection with other embodiments, whether or not explicitly described.
It would be apparent to one of skill in the relevant art that the embodiments described below can be implemented in many different embodiments of software, hardware, firmware, and/or the entities illustrated in the figures. Any actual software code with the specialized control of hardware to implement embodiments is not limiting of this description. Thus, the operational behavior of embodiments is described with the understanding that modifications and variations of the embodiments are possible, given the level of detail presented herein.
Generally speaking, some embodiments described herein provide a simplified approach for device users to manage content items on one or more devices using a network-based application. In different embodiments, devices that can be manipulated include mobile devices, such as mobile phones, and non-mobile devices, such as set-top boxes (STBs) and computers. It is important to note that, while an exemplary embodiment is described with the discussion of
In an embodiment, a network-based application is provided that displays user manipulable graphical representations of the managed devices. User manipulations can involve changing, adding and deleting content items on the managed devices. In an embodiment, once the changes are made in the network-based application, the changes can be effected automatically on the one or more devices by sending a modification request to the devices over a network.
As used herein, network 101 may be any network or combination of networks that can carry data communications. Such network 101 can include, but is not limited to, a local area network, medium area network, and/or wide area network such as the Internet. Network 101 can support protocols and technology including, but not limited to, World Wide Web protocols and/or services. Intermediate web servers, gateways, or other servers may be provided between components of the depicted network components depending upon a particular application or environment.
As used herein, mobile device 110 may be any type of portable microprocessor-based, user operated device. Typically, as used herein, mobile device 110 may refer to: a mobile phone, a smart phone and a tablet computer. An exemplary embodiment of mobile device 110 includes wireless connectivity through a broadband wireless network, for example mobile device 110 using wireless signal 150 to connect to network 101 via wireless transceiver 160. As noted above, non-mobile devices can also be managed by embodiments, in approaches similar to those discussed with respect to mobile device 110.
As used typically herein, a network-based application is an application with functions distributed between two or more computers linked by a network. In an embodiment of a network-based application described herein, content item verifying and processing functions are performed on a server computer and a user interface is hosted on a client computer. In this example, the client and server computers are linked by a network, for example, the Internet, the client user interface generated using a hypertext transfer protocol (HTTP), and executed with a web browser. In different embodiments, different configurations, functions, networks and computers can be used.
In the example embodiment noted above, the network-based application is a World Wide Web (WWW) based application executed using a web browser, e.g., DM application 145 executed by web browser 140 in
As would be appreciated by one having skill in the relevant art(s), network-based applications generally have a server-side component, e.g., server 120. Server 120 has the host/server-side components of DM application 145, and links, via network 101 to components on mobile device 110, client computer 180 and content server 130. Further details regarding the operation of different synchronization components on mobile device 110 are provided with the description of
In an example, network application architecture 100 supports a method of changing, with a DM application 145, a content item on mobile device 110. Mobile device 110 sends a content item, via wireless transceiver 160 and network 101, to server 120. Server 120 sends the content item to DM application 145 for display to a user as device representation 115.
When a user modifies device representation 115, DM application 145 sends a corresponding request for modification to server 120. Server 120 sends the request for modification to the mobile device 110. At mobile device 110, the request for modification is received and the corresponding content item is modified in accordance with the modification request.
In another example, network application architecture 100 supports method of adding a content item to a mobile device 110 with a DM application 145. Mobile device 110 sends a content item inventory, via wireless transceiver 160 and network 101, to server 120. Server 120 sends the content item inventory to DM application 145 for display to a user as device representation 115.
When a user, by modifying device representation 115, indicates a request to add a content item to mobile device 110, DM application 145 sends a corresponding request for addition to server 120. Server 120 receives the request for addition and sends the request for addition of the content item and the content item to mobile device 110. The content item can be stored in server storage 170 or provided to server 120 by different sources, including content server 130 and client computer 180.
At mobile device 110, the request for addition and the content item are received and the content item is added to mobile device 110. The following sections detail additional embodiments where content items are modified and added to different devices using a process similar to the one described above.
Further details and embodiments are provided below, according to different embodiments.
As used broadly herein for embodiments, a “content item” can refer to a variety of different items stored on mobile device 110. Items C1-C6 listed below are intended to be non-limiting examples of different types of content items. Example content items C1-C6 are listed as follows:
C1. Playlists: Example playlist 235 stores and displays a list of song references 232A-B. Each song reference 232A-B refers respectively to corresponding songs 272A-B stored in device storage 270. Thus, in an embodiment, a playlist is a content item that contains one or more references to other content items, for example, songs. An example of a modification to the playlist content item includes the addition and removal of song references from the playlist, and changing the display names of the songs in playlist 235.
C2. Device Settings: Device settings are content items that store configuration information used by mobile device 110 to configure different aspects of the device. Further details regarding device settings as content items are provided with the description of
C3. Application Shortcuts: Application shortcuts are a content item that store a reference to an application installed on mobile device 110. Applications also can be content items that perform functions. Further details regarding application shortcuts as content items are provided with the description of
C4. Wallpaper: Wallpaper is a content item that is displayed as a background image on device UI 230 of mobile device 110. Further details regarding wallpaper as content items are provided with the description of
C5. Application Data: Application data content items are stored to provide data to different device applications: word processing files, spreadsheet files, audio files, video files and picture files.
C6. Folders: Example folder 237 stores and displays a list of file references 233A-B. Each file reference 233A-B refers respectively to corresponding files 273A-B stored in device storage 270. Similar to playlist 235 above, in an embodiment, folder 274 is a content item that contains one or more references to other content items, e.g., files 273A-B and application data examples described with item C5 above.
As would be appreciated by one having skill in the relevant art(s), given the description of content item examples C1-C6, other types of data stored on a managed device can be added, removed and modified using the approaches described herein.
In an embodiment, when using mobile device 110, user 105 interacts with mobile device 110 via device UI 230, such interaction potentially including the display of playlist 235, the visual and/or audio presentation of content items: playing videos, displaying pictures and playing audio content. Other interactions that can be enabled by device UI 230 include removing, copying and adding content items to mobile device 110. To support modification of a content item, information describing a content item can also be sent to a device using the network application.
As would be appreciated by one having skill in the relevant art(s), given the description herein, user 105 can have a familiarity with device UI 230 such that interacting with content items as illustrated above, can be accomplished faster than with using a user interface with which they are unfamiliar. An embodiment realizes an advantage in user experience by replicating, using a network-based application, the device UI of managed devices.
In an embodiment, to support DM application 145, content item sender 265 sends content items to server 120. In another embodiment, content item sender 265 sends an inventory of content items to server 120. From server 120, as described in further detail below, the content items and content item inventory are used in DM application 145.
In an embodiment, UI synchronizer 250 monitors device UI 230 and sends information that corresponds to the current state of device UI 230 to server 120. In a different embodiment, UI synchronizer 250 sends comprehensive user interface information to server 120, including different characteristics of the behavior of device UI 230. For example, UI synchronizer 250 can send sufficient information such that behavior of device UI 230 can be graphically replicated by server 120 and DM application 145 on the display screen of client computer 180. Further details regarding this replication behavior and the implementation of UI synchronizer 250 are provided with the description of 3, 5 and 7, below.
Request to Modify a Content Item
In an example not intended to be limiting, mobile device 110 is a GOOGLE NEXUS ONE™ phone offered by Google Inc., of Mountain View, Calif., and device representation 395 is an image or detailed line drawing of a GOOGLE NEXUS ONE phone.
In keeping with device representation 395 being a realistic depiction of mobile device 110, device UI representation 331 is a realistic representation of device UI 230 from
As noted above with the description of
It should be noted that, in different embodiments, it is not required that device UI representation 331 display exactly what currently appears on device UI 230, it is sufficient that the representation appear similar to a user. In other embodiments, device UI 230 and device UI representation 331 are synchronized by UI synchronizer 250 in real-time, substantially real-time or some other delay period. In another embodiment, device representation 395 is not used for manipulation of content items, the manipulation being performed by a classic menu-driven application approach.
Referring to aspects of
S1. Using web browser 140 operated on client computer 180, user 105 initiates a connection through network 101 to server 120.
S2. The connection established between client computer 180 and server 120 enables the initiation of a DM application 345. As noted about with the description of
S3. As noted above, DM application 345 displays device representation 395, such device representation 395 being a graphical representation of device UI 230. DM application 345 displays device representation 395 as a manipulable user interface component. By manipulating device representation 395, user 105 can view, modify, add and delete content items are located on mobile device 110.
S4. Using device representation 395 in DM application 345, user 105 can delete, copy, move and otherwise manipulate content items stored on mobile device 110. In different embodiments, the manipulating of content items shown in device representation 395 can be performed using at least one of the steps of: using a pointer to manipulate a graphical depiction of a physical control found on the device (e.g. knob 393), using a pointer to perform gestures on the physical depiction of the device user interface, using a pointer to manipulate the graphical depiction of the device in a simulated three dimensional display, using a pointer to cause the graphical depiction of the device to be graphically linked to a graphical depiction of a connector, cable or dock, using a pointer to manipulate a graphical depiction of a hinged portion of the device, using a pointer to manipulate a graphical depiction of a sliding portion of the device, and using a pointer to type on a graphical depiction of a keyboard found on the device.
S5. After the user manipulates content items represented on device representation 395, a request to modify the manipulated content items is generated by DM application 345. For example, if the user removes song reference 332B from playlist 335, a corresponding request for modification of mobile device 110 is created by DM application 345. As noted above, playlist 335 corresponds to playlist 235 on mobile device 110. Based on the manipulation of playlist 335 on device UI representation 331, a request to modify playlist 235 on mobile device 110 is generated.
S6. DM application 345 via client computer 180 and network 101, sends the generated request to modify playlist 235 to mobile device 110.
Steps S1-S6 above are intended to illustrate an example series of steps that can be performed with embodiments. As would be appreciated by one having skill in the relevant art(s), given the description herein, additional similar steps may be performed using embodiments, and/or not all of the above noted steps S1-S6 may be performed. In addition, steps S1-S6 may be performed in a different order by embodiments.
Manipulating Content Items
It should be appreciated that requests to modify content items can involve a broad variety of different actions. In an example not intended to be limiting, a request for modification can include one or more of the following instructions F1-F5 listed below:
F1. An instruction to remove a content item from device storage 270. For example a particular music file stored in device storage 270 can be deleted. In this case, the content item is the inventory of device storage 270.
F2. An instruction to rename a content item from device storage 270. For example a particular music file stored in device storage 270 can be renamed.
F3. An instruction to move or copy a content item from device storage 270. In this case, the content item is the inventory of device storage 270, and this inventory is modified to copy or move a file to another location. For example song 272B, stored in device storage 270 can be copied from one logical storage area (in device storage 270.
F4. Receive an instruction from server 120 to change setting of mobile device 110. For example, an instruction to the ringer volume of mobile device 110 can be received and implemented by device synchronizer 240.
F5. Receive an instruction from server 120 to receive a content item from server 120. For example, a music file can be received by mobile device 110 and stored in device storage 270.
As would be appreciated by one having skill in the relevant art(s), given the description herein, the instructions F 1-F5 above illustrate the broad variety of instructions that can be directed to content items stored on a managed device.
Content item modifier 260 from
Device Settings
As noted in item C2 with the description of
In keeping with device representation 595 being a realistic depiction of mobile device 110, device UI representation 531 is a realistic representation of device UI 430 from
As described above with
Application Shortcuts
As noted with item C3 in the description of
In keeping with device representation 795 being a realistic depiction of mobile device 110, device UI representation 731 is a realistic representation of device UI 630 from
As described above with
As discussed in the embodiment of
In an embodiment, UI replicator 830 receives the UI information from UI synchronizer 250 and sends UI display information to DM application 145. On DM application 145, device representation 115 can be created for user 105 based on the information sent by UI replicator 830. The information gathered and sent by UI synchronizer 250 enables a display in DM application 145 of the content item as it would appear on a display of the mobile device both before and after a requested modification to the content item is performed.
As also described above with the description of
The following list L1-L4 is intended to be an illustrative, non-limiting list of different characteristics of content items that can be verified. In different embodiments, characteristics can be pre-determined or configured by a user. Items L1-L4 are as follows:
L1. Whether the content item has a valid license under a digital rights management (DRM) structure. For example, a song uploaded by a user may not have a current license. Content verifier 840, in this example, can prevent the song from being distributed to managed devices. In another embodiment, content verifier 840 can provide notification to the user about different determined content item characteristics. For example, in the missing license example above, the user can be notified about the lack of current license.
L2. Whether a content item is compatible with a managed device. As described further below with the description of
L3. Whether a compressed media content item has a sufficient bit rate to maintain a playback quality level. This is an example of a potentially user-defined verification characteristic. Because of audio quality requirements, for example, a user can specify that all audio files on managed devices have at least a 128 kbps bit rate.
L4. Different devices can have different specialized capabilities, for example a telephonic device can have capabilities with respect to playing polyphonic ring tones, while a laptop computer using a telephonic application may not have the capability. Content verifier 840 can be configured to determine whether a device can use a content item before the content item is sent to the device.
As would be appreciated by one having skill in the relevant art(s), given the description herein, items L1-L4 above illustrate that a variety of different verification characteristics can be used by content verifier 840, according to embodiments.
As discussed above with
According to an embodiment, DM application is also configured to receive content items and transfer these to mobile device 110. For example, compact disk 965 has one or more songs (content items), and I/O component 920 can manage the retrieval and conversion of these songs into an electronic format usable by mobile device 110. A user working with DM application 945 sees file source 942 and manipulates it as a graphical representation of compact disk 965. The content item manipulation functions described above are described with
In an embodiment, to enable the addition of song 960 to mobile device 110, server 120 receives a content inventory from mobile device 110 and uses this information to generate device representation 915 in DM application 945. User 105 can use the graphical manipulation approaches described with
Once content item song 960 has been requested for addition, song 960 can be uploaded from client computer to server 120 and transferred to mobile device 110. As would be appreciated by one having skill in the relevant art(s), given the description herein, content items can come from a variety of sources, for example, server 120, a connected server configured to store content items (content server 130), client computer 920, a device connected to client computer 920 (camera 930) and from another device managed by embodiments (as discussed with the description of
As used herein, set-top box (STB) 1060, also known as a set-top unit (STU), typically refers to a device that connects to a television/video display and an external source of signal, turning the signal into content which can then be stores and displayed, for example set-top box 1060 receiving a signal from network 101 and displaying content on video display 1030. An example embodiment of set-top box 1060 is the GOGGLE TV component offered by Google Inc., of Mountain View, Calif.
In different embodiments, the approaches to modifying, adding and removing content items on devices can be used to manage content items across multiple devices in an integrated fashion. In an example, user 105 desires to modify a content item on multiple mobile devices and non-mobile devices using a single integrated approach. Using the approach described with the description of
It should be appreciated that different embodiments can add and remove content items from associated devices using a variety of different approaches. Approaches used by embodiments include a content item synchronization approach, where adding, modifying or removing content items on one device automatically leads to the same result on a related device. For example, adding a content item to netbook 1066 can be synchronized with mobile device 1010A via server 120 and approaches described herein. Device settings, as discussed with the description of
As would be appreciated by one having skill in the relevant art(s), given the description herein, different content items can have different configurations based on the type of content device upon which they are used. For example, an encoded music file (e.g., MP3 encoded audio) can have different bit rate configurations based on the amount of storage available on a device.
In an example, using processes described
As noted above, configuration settings can also be appled to coupled devices using an embodiment. As with the different versions of content items sent to different types of devices described above, configuration settings can also be modified before being sent out to different types of devices. For example, an embodiment can be configured such that configuration changes to tablet computer 1065 are sent and implemented at mobile device 1010A. If, for example, a user selects a background color on tablet computer 1065 that does not exist on mobile device 1010A, a similar background color can be selected and sent to mobile device 1010A.
In an example that combines both configuration synchronization and content item synchronization across multiple devices, a user may be attending a concert by a particular band and Multiple types of related content items can be sent to connected devices. Using an embodiment, music from the band (encoded with appropriate bit-rates) can be added to multiple connected devices, e.g., mobile devices 1010A-B, set-top box 1060 and netbook 1066. In addition, the wallpaper configuration of these devices can also be changed to present graphics related to the band. On selected devices, e.g., telephonic devices 1010A-B, a ringtone configuration can also be changed.
Method 1100
At stage 1104, the content item is sent to a client computer, and on the client computer the content item is presented to a user with the network-based application by displaying a graphical depiction of the device, the graphical depiction showing the content item as it would appear on a display of the device. For example, in an embodiment, the content item, for example playlist 235, is sent to a client computer, for example client computer 180 from
At stage 1106, a request for a modification of the content item is received from the client computer using the network-based application. For example, in an embodiment, a request to modify a content item, for example a request to remove a song 332A from playlist 335, is received from the client computer using the network-based application, for example client computer 180 using DM application 145.
At stage 1110, the request for the modification is sent to the mobile device over the network. For example, in an embodiment, the above-noted request for modification, the request to remove a song 332A from playlist 335, is sent to the device, for example mobile device 110. At mobile device 110, the request for modification is received by content item modifier 260, and the corresponding, stored playlist 271, has corresponding song 272A removed. After stage 1110, method 1100 ends at 1112.
If programmable logic is used, such logic may execute on a commercially available processing platform or a special purpose device. One of ordinary skill in the art may appreciate that embodiments of the disclosed subject matter can be practiced with various computer system and computer-implemented device configurations, including smartphones, cell phones, mobile phones, tablet PCs, multi-core multiprocessor systems, minicomputers, mainframe computers, computer linked or clustered with distributed functions, as well as pervasive or miniature computers that may be embedded into virtually any device.
For instance, at least one processor device and a memory may be used to implement the above described embodiments. A processor device may be a single processor, a plurality of processors, or combinations thereof. Processor devices may have one or more processor ‘cores.’
Various embodiments of the invention are described in terms of this example computer system 1200. After reading this description, it will become apparent to a person skilled in the relevant art how to implement the invention using other computer systems and/or computer architectures. Although operations may be described as a sequential process, some of the operations may in fact be performed in parallel, concurrently, and/or in a distributed environment, and with program code stored locally or remotely for access by single or multi-processor machines. In addition, in some embodiments the order of operations may be rearranged without departing from the spirit of the disclosed subject matter.
Processor device 1204 may be a special purpose or a general purpose processor device. As will be appreciated by persons skilled in the relevant art, processor device 1204 may also be a single processor in a multi-core/multiprocessor system, such system operating alone, or in a cluster of computing devices operating in a cluster or server farm. Processor device 1204 is connected to a communication infrastructure 1206, for example, a bus, message queue, network or multi-core message-passing scheme.
Computer system 1200 also includes a main memory 1208, for example, random access memory (RAM), and may also include a secondary memory 1210. Secondary memory 1210 may include, for example, a hard disk drive 1212, removable storage drive 1214 and solid state drive 1216. Removable storage drive 1214 may include a floppy disk drive, a magnetic tape drive, an optical disk drive, a flash memory, or the like. The removable storage drive 1214 reads from and/or writes to a removable storage unit 1218 in a well known manner Removable storage unit 1218 may include a floppy disk, magnetic tape, optical disk, etc. which is read by and written to by removable storage drive 1214. As will be appreciated by persons skilled in the relevant art, removable storage unit 1218 includes a computer usable storage medium having stored therein computer software and/or data.
In alternative implementations, secondary memory 1210 may include other similar means for allowing computer programs or other instructions to be loaded into computer system 1200. Such means may include, for example, a removable storage unit 1222 and an interface 1220. Examples of such means may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 1222 and interfaces 1220 which allow software and data to be transferred from the removable storage unit 1222 to computer system 1200.
Computer system 1200 may also include a communications interface 1224. Communications interface 1224 allows software and data to be transferred between computer system 1200 and external devices. Communications interface 1224 may include a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA slot and card, or the like. Software and data transferred via communications interface 1224 may be in electronic, electromagnetic, optical, or other forms capable of being received by communications interface 1224. This data may be provided to communications interface 1224 via a communications path 1226. Communications path 1226 carries the data and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link or other communications channels.
In this document, the terms “computer program medium” and “computer usable medium” are used to generally refer to media such as removable storage unit 1218, removable storage unit 1222, and a hard disk installed in hard disk drive 1212. Computer program medium and computer usable medium may also refer to memories, such as main memory 1208 and secondary memory 1210, which may be memory semiconductors (e.g., DRAMs, etc.).
Computer programs (also called computer control logic) may be stored in main memory 1208 and/or secondary memory 1210. Computer programs may also be received via communications interface 1224. Such computer programs, when executed, enable computer system 1200 to implement the present invention as discussed herein. In particular, the computer programs, when executed, enable processor device 1204 to implement the processes of the present invention, such as the stages in the method illustrated by flowchart 1100 of
Embodiments of the invention also may be directed to computer program products comprising software stored on any computer useable medium. Such software, when executed in one or more data processing devices, causes a data processing device(s) to operate as described herein. Embodiments of the invention employ any computer useable or readable medium. Examples of computer useable mediums include, but are not limited to, primary storage devices (e.g., any type of random access memory), secondary storage devices (e.g., hard drives, floppy disks, CD ROMS, ZIP disks, tapes, magnetic storage devices, and optical storage devices, MEMS, nanotechnological storage device, etc.).
Embodiments described herein relate to the manipulation of device content using a network based application. The summary and abstract sections may set forth one or more but not all exemplary embodiments of the present invention as contemplated by the inventors, and thus, are not intended to limit the present invention and the claims in any way.
The embodiments herein have been described above with the aid of functional building blocks illustrating the implementation of specified functions and relationships thereof. The boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries may be defined so long as the specified functions and relationships thereof are appropriately performed.
The foregoing description of the specific embodiments will so fully reveal the general nature of the invention that others may, by applying knowledge within the skill of the art, readily modify and/or adapt for various applications such specific embodiments, without undue experimentation, without departing from the general concept of the present invention. Therefore, such adaptations and modifications are intended to be within the meaning and range of equivalents of the disclosed embodiments, based on the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by the skilled artisan in light of the teachings and guidance.
The breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the claims and their equivalents.