The present application relates generally to configuring a UI based on the context of what a user is doing.
With the increased prevalence of mobile devices such as smart phones and tablet computers comes the desirability to use them in particular contexts, such as while driving a vehicle or riding as a passenger in one. However, present principles recognize that current user interfaces that are presentable on such mobile devices to undertake certain functions that may be useful while driving are often difficult and indeed distracting to invoke and manipulate (e.g., owing to their complexity and/or their “cluttered” appearance) while driving.
Accordingly, the present application provides systems, apparatuses, and methods for presenting, e.g., useful mobile device applications/application icons, notifications and/or other mobile device functions to a user in an easily and quickly viewable format. The present application also recognizes the desirability of automating this presentation rather than having to manually switch back and forth between at least one user interface when not driving a vehicle and at least one while driving a vehicle, though present principles nonetheless recognize that such manual switching may still be desirable in certain contexts.
Accordingly, in one embodiment an apparatus includes a computer readable storage medium that is not a carrier wave and that is accessible to a client processor of a client device and bearing instructions which when executed by the client processor configure the processor to execute logic to execute a method that includes, based on a determination that the client processor is in a vehicle, automatically presenting on a display a user interface (UI) in a first configuration for allowing selection of one of plural applications represented on the UI. Based on a determination that the client processor is not in a vehicle, the instructions cause the processor to automatically present on the display the UI in a second configuration for allowing selection of one of plural applications represented on the UI, the second configuration being different from the first configuration. In some implementations the display may be a client device display, and the client device may include the client processor.
Furthermore, in some embodiments, the plural applications may be represented on the UI by selectable tiles such that the first configuration may present relatively fewer tiles than the second configuration and/or present tiles in at least one larger dimension relative to tiles presented in the second configuration. Moreover, if desired the first and second configurations may differ from each other based on the particular applications represented on the UI.
Also in some embodiments, the UI of the first configuration may be automatically presented on the display based on a determination not only that the client processor is in the vehicle but also that the vehicle is in gear.
In another aspect, a method includes determining whether a client device is disposed in a vehicle and, based on a determination that the client device is disposed in a vehicle, automatically presenting a first user interface (UI) on a display of the client device including relatively less information than a second UI presentable on the display where the second UI is presentable on the display based on a determination that the client device is not disposed in a vehicle.
In yet another aspect, an apparatus includes at least one computer readable storage medium that is not a carrier wave and that is accessible to a client processor and bears instructions which when executed by the client processor configure the processor to execute logic to execute a method that includes determining whether a user activity trigger satisfies a test, where the user activity trigger is motion of a client device associated with the client processor as represented by a signal input to the client processor and/or use of the client device to execute a predetermined application. Responsive to a determination that the user activity trigger satisfies the test, a first output is presented on the client device, whereas responsive to a determination that the user activity trigger does not satisfy the test, a second output is presented on the client device. It is to be understood that the second output is different from the first output.
The details of the present invention, both as to its structure and operation, can best be understood in reference to the accompanying drawings, in which like reference numerals refer to like parts, and in which:
Disclosed are methods, apparatus, and systems for computer based user information. A system herein may include server and client components, connected over a network such that data may be exchanged between the client and server components. The client components may include one or more computing devices. These may include personal computers, laptops, tablet computers, and other mobile devices including smart phones. These client devices may operate with a variety of operating environments. For example, some of the client computers may be running Microsoft Windows® operating system. Other client devices may be running one or more derivatives of the Unix operating system, or operating systems produced by Apple® Computer, such as the IOS® operating system, or the Android® operating system, produced by Google®. While examples of client device configurations are provided, these are only examples and are not meant to be limiting. These operating environments may also include one or more browsing programs, such as Microsoft Internet Explorer®, Firefox, Google Chrome®, or one of the other many browser programs known in the art. The browsing programs on the client devices may be used to access web applications hosted by the server components discussed below.
Server components may include one or more computer servers executing instructions that configure the servers to receive and transmit data over the network. For example, in some implementations, the client and server components may be connected over the Internet. In other implementations, the client and server components may be connected over a local intranet, such as an intranet within a school or a school district. In other implementations a virtual private network may be implemented between the client components and the server components. This virtual private network may then also be implemented over the Internet or an intranet.
The data produced by the servers may be received by the client devices discussed above. The client devices may also generate network data that is received by the servers. The server components may also include load balancers, firewalls, caches, and proxies, and other network infrastructure known in the art for implementing a reliable and secure web site infrastructure. One or more server components may form an apparatus that implement methods of providing a secure community to one or more members. The methods may be implemented by software instructions executing on processors included in the server components. These methods may utilize one or more of the user interface examples provided below in the appendix.
The technology is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, processor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
As used herein, instructions refer to computer-implemented steps for processing information in the system. Instructions can be implemented in software, firmware or hardware and include any type of programmed step undertaken by components of the system.
A processor may be any conventional general purpose single- or multi-chip processor such as the AMD® Athlon® II or Phenom® II processor, Intel® i3®/i5®/i7® processors, Intel Xeon® processor, or any implementation of an ARM® processor. In addition, the processor may be any conventional special purpose processor, including OMAP processors, Qualcomm® processors such as Snapdragon®, or a digital signal processor or a graphics processor. The processor typically has conventional address lines, conventional data lines, and one or more conventional control lines.
The system is comprised of various modules as discussed in detail. As can be appreciated by one of ordinary skill in the art, each of the modules comprises various sub-routines, procedures, definitional statements and macros. The description of each of the modules is used for convenience to describe the functionality of the preferred system. Thus, the processes that are undergone by each of the modules may be arbitrarily redistributed to one of the other modules, combined together in a single module, or made available in, for example, a shareable dynamic link library.
The system may be written in any conventional programming language such as C#, C, C++, BASIC, Pascal, or Java, and run under a conventional operating system. C#, C, C++, BASIC, Pascal, Java, and FORTRAN are industry standard programming languages for which many commercial compilers can be used to create executable code. The system may also be written using interpreted languages such as Pert Python or Ruby. These are examples only and not intended to be limiting.
Those of skill will further appreciate that the various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the embodiments disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
The various illustrative logical blocks, modules, and circuits described in connection with the embodiments disclosed herein may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
In one or more example embodiments, the functions and methods described may be implemented in hardware, software, or firmware executed on a processor, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a, computer-readable medium. Computer-readable media include both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. However, a computer readable storage medium is not a carrier wave, and may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable storage media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
The foregoing description details certain embodiments of the systems, devices, and methods disclosed herein. It will be appreciated, however, that no matter how detailed the foregoing appears in text, the systems, devices, and methods can be practiced in many ways. As is also stated above, it should be noted that the use of particular terminology when describing certain features or aspects of the invention should not be taken to imply that the terminology is being re-defined herein to be restricted to including any specific characteristics of the features or aspects of the technology with which that terminology is associated.
It will be appreciated by those skilled in the art that various modifications and changes may be made without departing from the scope of the described technology. Such modifications and changes are intended to fall within the scope of the embodiments. It will also be appreciated by those of skill in the art that parts included in one embodiment are interchangeable with other embodiments; one or more parts from a depicted embodiment can be included with other depicted embodiments in any combination. For example, any of the various components described herein and/or depicted in the Figures may be combined, interchanged or excluded from other embodiments.
With respect to the use of substantially any plural and/or singular terms herein, those having skill in the art can translate from the plural to the singular and/or from the singular to the plural as is appropriate to the context and/or application. The various singular/plural permutations may be expressly set forth herein for sake of clarity.
It will be understood by those within the art that, in general, terms used herein are generally intended as “open” terms (e.g., the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” etc.) It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases “at least one” and “one or more” to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim recitation to embodiments containing only one such recitation, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an” (e.g., “a” and/or “an” should typically be interpreted to mean “at least one” or “one or more”); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should typically be interpreted to mean at least the recited number (e.g., the bare recitation of “two recitations,” without other modifiers, typically means at least two recitations, or two or more recitations). Furthermore, in those instances where a convention analogous to “at least one of A, B, and C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, and C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). In those instances where a convention analogous to “at least one of A, B, or C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, or C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). It will be further understood by those within the art that virtually any disjunctive word and/or phrase presenting two or more alternative terms, whether in the description, claims, or drawings, should be understood to contemplate the possibilities of including one of the terms, either of the terms, or both terms. For example, the phrase “A or B” will be understood to include the possibilities of “A” or “B” or “A and B.” While various aspects and embodiments have been disclosed herein, other aspects and embodiments will be apparent to those skilled in the art. The various aspects and embodiments disclosed herein are for purposes of illustration and are not intended to be limiting.
Referring initially to
Among the non-limiting and example components a client device 12 may incorporate, a processor 22 accesses a computer readable storage medium 24 that contains instructions which when executed by the processor configure the processor to undertake principles disclosed below. The client device 12 may communicate with other client devices using a wireless short range communication interface 26 such as but not limited to a Bluetooth transceiver controlled by the processor 22. Also, the client device 12 may communicate with the cloud 14 using a wireless network interface 28 such as but not limited to one or more of a WiFi transceiver, wireless modem, wireless telephony transceiver, etc. controlled by the processor 22. Wired interfaces 26, 28 are also contemplated.
The client device typically includes a visual display 30 such as a liquid crystal display (LCD) or light emitting diode (LED) display or other type of display controlled by the processor 22 to present demanded images. The display 30 may be a touch screen display. In addition, one or more input devices 32 may be provided for inputting user commands to the processor 22. Example input devices include keypads and keyboards, point-and-click devices, a microphone inputting voice commands to a voice recognition engine executed by the processor 22, etc. A position sensor 34 may input signals to the processor 22 representing a location of the client device 12. While
Now in reference to
Regardless, reverting back to decision diamond 60, if an affirmative determination is instead made at this point in the logic, the exemplary logic of
Continuing in reference to
In addition, though not forming part of the exemplary logic discussed above, it is to be understood that other “triggers” besides a motion threshold may be used in accordance with present principles to cause a driving UI to be presented. For example, invocation of a particular icon representing an application can constitute a trigger to thereby cause a driving UI to be presented. As an example, should a traffic application icon be invoked, this can cause the processor to determine that a driving UI should be presented.
Examples of UIs optimized for manipulation while driving in contrast to “normal” UIs for presentation, viewing, and/or manipulation while not driving are shown in
Two more exemplary driving UIs in accordance with present principles are shown in
Either way, it may be appreciated that the exemplary UI 80 of
Thus, an exemplary focused driving UI 94 is shown in
Furthermore, a contact selector element 100 is also shown on the UI 94 and is presented in such a way (e.g., partially overlapping the notification 94) so that it is easily discernable that the contact represented by the element 100 is indeed associated with the meeting (e.g., another meeting participant), and is easily selectable while driving. The element 100 is therefore selectable to cause, e.g., a telephone or text messaging application to launch or to otherwise be used to contact the person represented by the element 100. Likewise, a navigation selector element 102 may also be presented on the UI 94 in such a way (e.g., partially overlapping the notification 94) so that it is easily discernable that selection of the element 102 may cause navigation assistance to be presented (e.g., directions to the meeting associated with the notification 96), and indeed the element 102 is presented in such a way that it is easily selectable while driving. Also note that a background image 106 may also be presented to make it even easier for a user discern while driving that all of the icons/selector elements and notifications that are overlapping or encompassed by the image 106 are in some respect associated with the same subject matter (in this case, the meeting to which the notification 96 centrally disposed on top of the image 106 pertains). For completeness, also note that alternate contacts may be represented by plural respective icons 104, where those contacts may be but are not necessarily associated with the upcoming meeting with which the notification 96 is directed.
Momentarily reverting back to
Yet another exemplary UI optimized for manipulation and viewing while driving is shown in
Regardless of whether the items 112 or particular icons or other aspects/information respectively contained therein (e.g., selectable text) are selectable or not, it is to be further understood each item may present its information, e.g., in bold face type, with a solid underline, with a dotted underline, with highlighting, in text colors other than black, in italics, in any number of font types such as e.g. Times New Roman or Cambria, and/or in relatively large font (e.g., as compared to a “normal” UI when the device is not in a moving vehicle) that is easy to glance at for information while driving or otherwise quickly and easily draws the attention of a user so as to, e.g., not consume an undue amount of the viewer's time deciphering information while also driving and thus creating a safety hazard. Furthermore, as may be appreciated from
Moving on to
Regardless, should the logic instead determine at diamond 118 that the vehicle in which the client device executing the logic of
Examples of other parameters are the current location of the device or predicted destination, the time of day, time of month, time of year, etc., recent activities, recent selections of the same or even different icons and associated applications, driving conditions and even appropriateness and ability of a user to use a particular function when accounting for driving conditions (e.g., sitting in traffic may not be an optimal time to type an email but may nonetheless be a time for quickly glancing at the text of an email sent to the user).
Accordingly, should the logic move from diamond 118 to block 122, an example of a driving UI that may be presented using an email application may be an email composition screen rather than an inbox screen that would otherwise be presented as a “normal” UI. As another example, should a telephone application be invoked, a driving UI that may be presented would include an icon for a particular one of the user's contacts that is selectable using, e.g., a single touch to “speed dial” the contact, where that contact was predicted by the application to be the person the user is driving to meet based on, e.g., the direction of movement of the vehicle and/or electronic calendar entries accessible to the device and/or phone application.
Reference is now made to
Moving on to
Now in reference to
Now describing
Turning now to
Continuing the detailed description in reference to
It may now be appreciated that various particular functions of an application may be presented and manipulated by a user when driving a vehicle as opposed to when the application is invoked in, e.g., a living room setting. However, present principles recognize that particular functions may not only be predicted, but indeed the applications themselves that a user is likely to invoke may also be predicted. Logic for predicting applications likely to be invoked while driving is therefore shown in
Thus,
The exemplary logic may then conclude at block 182, where the logic presents a driving UI that includes one or more icons predicted by the logic to be of relevance and/or useful to the user of the device when considering certain parameters such as those described above. Before moving on to the description of the next figure, it is to be understood that not all of the steps of, e.g., blocks 174 through 180 need be undertaken much less in the order described above, and that, e.g., any combination or only a single one of them may be undertaken.
Now in reference to
Continuing the detailed description in reference to
Thus, it may now be appreciated that position sensors such as a GPS receiver and/or accelerometer or any of the other exemplary position sensors described above may be used in accordance with present principles so that a client device's processor may determine that the device is in a vehicle and that, e.g., the vehicle is moving, to then present a simplified UI that is easily manipulable and discernable to a user while driving (e.g., a simplified list or grid). Moreover, the simplified UI may dynamically change based on certain factors, applications, contexts, and parameters such as those described herein—e.g., past behavior and device usage, location, frequency of use, recent activities (e.g., the device determines that the user was recently at a professional sporting event and thereafter presents icons related to sports generally, a specific team, upcoming games for that team and/or game location, etc.), weather conditions, traffic conditions, road conditions, time of day, etc. Indeed, the client device is understood to be capable of predicting not just a location toward which the device is moving in a vehicle but even events to be participated in based not just on the user's calendar but also, e.g., information accessible to the device regarding public events in the area to which the device is moving and present applications/icons that may be useful in such a context accordingly. It is to thus be understood that such information, or any other information disclosed herein that is accessible by the client device, is accessible over, e.g., a server such as those described above and/or an Internet database.
Still further, media such as music, audio books, podcasts, and streaming audio may be represented on and manipulable through a driving UI. The applications/icons themselves may vary and be filtered based on the speed at which the vehicle in which the device is disposed is traveling. Such filtering and/or dynamic alteration of the driving UI or presentation of another driving UI may be undertaken based on, e.g., being late to a meeting as opposed to merely traveling to it on time such that icons for contacting another person attending the meeting may be presented to inform them of a late arrival, and even present an estimated time of arrival indicator in the message only when, e.g., the device determines that a late arrival at the meeting is likely. Incoming messages (e.g., text or email) that are flagged as being important can also be recognized by the client device as such and be presented on a driving UI, e.g., in a way to draw the user's attention.
Present principles also recognize many of the following features not specifically described in reference to the figures described above. First, note that a client device may communicate with, e.g., an on-board vehicle computer and vehicle display mounted on the vehicle such that any or all of the UIs described herein may be presented on the vehicle display in addition to or in lieu of presenting them on the display of the client device. Second, in addition to the foregoing features of a driving UI and switching/toggling between a driving UI and a “normal” UI, a client device processor may at certain points also determine that the vehicle in which it is disposed has stopped, e.g., in a parking lot or a red light, and upon such a determination present the “normal” UI for at least part of the time the vehicle is stopped, and possibly the entire duration. At such a time when the vehicle begins to move again (e.g., the signal switches to a green light), the client device processor may then present the driving UI again.
As but another example, the client device may have access to information enabling it to distinguish between the client device traveling on a road or traveling on, e.g., train tracks, by aircraft, by boat, etc. such that the client device processor may determine that even though the vehicle is traveling, it is not traveling on a public road and therefore the device's user may not be driving and hence, may not necessarily prefer a driving UI be presented on the device. Thus, e.g., should a user be riding in a train, the client device can access information such as map information of train tracks to determine that the device, while moving in a “vehicle” and above a motion threshold as described above, is not in an automobile and that a “normal” UI should be presented rather than a driving UI. Similar principles can be applied to a situation where the user of the client device is a passenger in a city bus or commuter bus based on determinations made by the client device processor accessing information indicating that the vehicle in which the device is disposed is a bus, and hence the user is predicted to not be the driver of the bus and hence a “normal” UI may be more appropriate for presentation than a driving UI.
Still other applications are possible. For instance, a client device processor may have access to information pertaining to state laws (and/or driving laws, regional laws, etc.) and hence present a driving UI, or even a particular presentation or configuration thereof, responsive to determining based on state law information it has accessed that only a certain type of presentation or configuration is legal, and thus present such a presentation or configuration in accordance with the state law in the state in which the device is disposed. In fact, should state law dictate that a screen should be locked only to a driving UI while a person is driving with the device such that a “normal” UI cannot be rendered, the device may have access to such information and lock the driving UT screen and/or any functions thereof such that a “normal” UI is not presented in such circumstances.
Describing yet another example, should a client device determine that it is indeed disposed in a moving vehicle, but the vehicle is nonetheless on non-public land such as a private ranch or parking lot, the device may determine that even though the device is moving in a vehicle, it should nonetheless present a “normal” UI based on, e.g., a user's preference as input to the device.
As a final example, it is to be understood that a client device presenting a driving UI in accordance with present principles may gather information such as voice commands, voice interactions, verbal statements and other natural language from the user, etc., and respond by updating the driving UI based on those statements. Thus, for example, should a conversation between the user and another person be directed toward a particular topic, the client device is capable of gathering and recognizing words spoken and present applications and information on a driving UI predicted to be relevant based on the context of the conversation. For example, if a user verbally asks “Who is attending my meeting?” the device can recognize the question as, e.g., a command to present information and/or an icon on a driving UI regarding who is attending the meeting and even present an icon selectable to render more information about the meeting and/or the meeting organizer, and/or even send an update to each person attending the meeting as they are listed in sequence (e.g., the client device can present an icon selectable a single time that contains words such as “Inform everyone you're going to be late?” that, based on a single manipulation or touch input from a user automatically causes the device processor, without further user input, to send notifications, text messages, emails, and/or social networking posts, etc., informing the other meeting participants that the user of the client device will be late to the meeting, and such a message to others can even include the user's ETA.
While the particular CONFIGURING USER INTERFACE (UI) BASED ON CONTEXT is herein shown and described in detail, it is to be understood that the subject matter which is encompassed by the present invention is limited only by the claims.