The disclosure herein relates generally to generating message notifications.
Many users of electronic mail (email) services receive a large number of email messages on a daily basis. In many cases, users receive email messages that are not relevant to them, and/or email messages that they do not wish to receive. Because of this, many email users spend a significant amount of time managing their email accounts, including assessing messages to determine the relevancy of each message, reading relevant messages, and deleting or ignoring irrelevant and/or unwanted email messages.
It has become common for users to have near-constant access to email via portable electronic devices, such as laptop computers, tablet computers, and computationally-enabled telephones (“smart phones”). Some of these devices output notifications that describe newly-received messages, such as by displaying the name of the sender of the message along with text from the message. Users also receive messages via services other than email, such as text messages (via a protocol such as the SMS protocol), chat messages, social media messages, application-generated messages, and other types of messages. Some portable electronic devices also output notifications regarding these types of messages along with notifications regarding email messages. Compounding the challenges presented by the volume of notifications received by users, emerging technologies such as wearable computing devices including “smart watches” will allow users to be instantly notified when a new email message is received, regardless of the activity that the user is currently engaged in.
The disclosure relates to generating message notifications.
One aspect of the disclosed embodiments is a method includes accessing, by one or more computers, a message, and identifying, at the one or more computers and based on information contained in the message, at least one topic related to the message. The method also includes identifying, at the one or more computers, a graphical topic indicator based on the at least one topic, and outputting, by the one or more computers and for display, a visual notification regarding the message, wherein the visual notification includes the graphical topic indicator.
Another aspect of the disclosed embodiments is an apparatus that includes one or more processors and one or more memory devices for storing program instructions used by the one or more processors. The program instructions, when executed by the one or more processors, cause the one or more processors to access a message and identify, based on information contained in the message, at least one topic related to the message. The program instructions further cause the one or more processors to identify a graphical topic indicator based on the at least one topic and output, for display, a visual notification regarding the message, wherein the visual notification includes the graphical topic indicator.
Another aspect of the disclosed embodiments is a method that includes accessing, by one or more computers, a message, and identifying, at the one or more computers and based on information contained in the message, a single word related to the message. The method further includes outputting, for display, a notification regarding the message, wherein the notification includes the single word related to the message, and the single word is the only text element included in the notification that is related to the message.
Another aspect of the disclosed embodiments is a method that includes, accessing, by one or more computers, a message, and outputting, for display at a client computing device, a visual notification regarding the message, wherein the visual notification includes a graphical topic indicator, a graphical sender indicator, and does not include text related to the message. The method also includes outputting, subsequent to outputting the visual notification and for display, text related to the message, and accepting as input, during a display time period, a first user input signal. The method also includes removing, from display, the text related to the message in response to passage of the display time period if the first user input signal is not received during the display time period, and removing, from display at the client computing device, the text related to the message in response to receiving a second user input signal, if the first user input signal is received during the display time period.
The description herein makes reference to the accompanying drawings wherein like reference numerals refer to like parts throughout the several views, and wherein:
Current email notifications provide text-based information such as a name of the sender and a subject line for the email message. Because reading is a serial process, meaning that a person's attention must be focused almost completely on the task of reading to accomplish it, these notifications do not provide meaningful information regarding the context of an email that can be understood without diverting the user's attention to the task of reading information such as a sender name and a subject line of the email. The methods taught herein are directed to providing meaningful information regarding a message that can be quickly understood by a user by glancing briefly at the notification. In some implementations, the methods taught herein identify a topic based on information in the email message, and output for display a visual notification that includes a graphical topic indicator that corresponds to the topic.
The systems, services, servers, and other computing devices described herein are in communication via a network 150. The network 150 can be one or more communications networks of any suitable type in any combination, including wireless networks, wired networks, local area networks, wide area networks, cellular data networks, and the internet.
The message service 130 provides a service that transmits messages to the user system 110. The description herein will be made with respect to a web-based email service that can provide a web-browser-based interface for viewing mailboxes and email messages. It should be understood, however, that the email service can be provided in many other forms, such as in the form of an “app” that is executed by a tablet computer, a smart-phone or other portable electronic device, or in the form of desktop software that is executed by a personal computer.
Each server computer 132 can include memory 220, such as a random access memory device (RAM). Any other suitable type of storage device can be used as the memory 220. The memory 220 can include code and data 222 that can be accessed by the CPU 210 using a bus 230. The memory 220 can further include one or more application programs 224 and an operating system 226. The application programs 224 can include software components in the form of computer executable program instructions that cause the CPU 210 to perform the operations and methods described herein.
A storage device 240 can be optionally provided in the form of any suitable computer readable medium, such as a hard disc drive, a memory device, a flash drive or an optical drive. One or more input devices 250, such as a keyboard, a mouse, or a gesture sensitive input device, receive user inputs and can output signals or data indicative of the user inputs to the CPU 210. One or more output devices can be provided, such as a display device 260. The display device 260, such as liquid crystal display (LCD) or a cathode-ray tube (CRT), allows output to be presented to a user, for example, in response to receiving a video signal.
Although
The conventional email interface screen 300 can include a control area 310 and a message area 320. The control area 310 can include various user operable interface elements, such as buttons, that can be utilized to perform actions with respect to an email message that is displayed within the message area 320. The message area 320 can display information corresponding to an email message, such as a name of a sender of the email message, a subject line for the email message, and a message body for the email message including text and/or images, which can be in plain text format or in a rich format, such as HTML.
In the illustrated example the email message that is displayed within the message area 320 of the conventional email interface screen indicates that the sender of the message has purchased a ticket for an event on behalf of the recipient of email message.
The graphical sender indicator 410 is a graphical element that is associated with a sender of the message to which message notification 400 corresponds. The graphical sender indicator can be any image or symbol that is chosen to represent the sender of the message. In some implementations, the graphical sender indicator 410 for a particular sender is chosen by the recipient of the message. In other implementations, the graphic element selected for the graphical sender indicator 410 is selected by the sender. In the illustrated example, the graphical sender indicator 410 is a photograph representing the sender of the message, and is displayed within a circular area. Other types of images, symbols, and shapes can be utilized in forming the graphical sender indicator 410.
The graphical topic indicator 420 represents a topic that is related to the message. The graphical topic indicator 420 can be any type of graphic, symbol or other visual element that is representative of at least one topic related to the message. In the illustrated example, the graphical topic indicator 420 is an icon representing a ticket and is based on information contained in the email message depicted within the message area 320 of the conventional email interface screen 300. The graphical element that is selected as the graphical topic indicator 420 is dependent upon information contained within the message to which the message notification 400 relates. The graphical topic indicator 420 can be, as example, an icon, an emoji, or a photographic image. Graphical elements in any suitable format can be used as the graphical topic indicator 420, such as raster formats and vector formats. In one implementation, as illustrated in
A message 510 is provided as an input to a message analyzer 520. The message 510 can be any manor of message, such as an email message, a text message, a chat message, a social media message, an application generated message, or any other type of message that can be delivered output for display at a computing device, such as the user system 110.
The message analyzer 520 is operable to analyze the message 510 and identify at least one topic that is related to the message 510. The analysis performed by the message analyzer 520 can be based on any or all of the identity of the sender of the message, the subject line of the message 510, the body of the message 510, metadata transmitted with the message 510, or any other type of information associated with the message 510. Any system, method, or algorithm now known or later developed can be utilized to identify the at least one topic related to the message 510 by the message analyzer 520. As a first example, the message analyzer 520 can compare the message to known message profiles. This type of system is well suited to automatically generated email messages, such as email messages confirming airline bookings, email messages containing receipts for online purchases, and shipping notifications regarding goods ordered by the recipient. Another type of algorithm that can be applied to identify at least one topic related to the message is a semantic analysis algorithm that identifies and ranks concepts that are contained within the text associated with the message, such as in a subject line and message body of an email message. Such an algorithm could return a ranked set of key words, responding to one or more topics that are associated with the message. Then, for example, the highest ranked topic could be selected for use in generating a notification, as will be described further herein. Other examples of methods that can be used to analyze a message by the message analyzer 520 include keyword frequency analysis within the text of the message 510, a machine learning classification model, and a classification model that utilizes filters that are associated with an email account or other messaging account that is associated with the user.
As an output, the message analyzer provides information identifying at least one topic related to the message to a notification generator 530. The notification generator 530 can also receive other information related to the message, including an identity of the sender of the message 510. The notification generator 530 can utilize the information identifying the at least one topic associated with the message 510 to identify a graphical topic indicator. In particular, the notification generator 530 can access a plurality of stored topic indicators 540, and select an appropriate topic indicator from the plurality of topic indicators 540 using the information received from the message analyzer 520. For example, a plurality of topic indicators 540 can be graphical elements that are stored in association with metadata describing one or more topics that each graphical element corresponds to. The notification generator 530 selects one of the topic indicators 540 based on a match between the at least one topic that was identified by the message analyzer 520 and information associated with the topic indicators 540, such as an exact match of the topic identified by the message analyzer 520 and a topic described by metadata associated with one of the topic indicators 540. The notification generator can further identify a graphical sender indicator. For example, the graphical sender indicator can be selected based on the identity of the sender of the message 510. In one implementation, a plurality of sender indicators 550 are scored in association with metadata describing an identity of a person associated with each of the sender indicators 550. The notification generator can determine whether a match is found, and if so, select the matching one of the sender indicators 550 for inclusion in a notification. Using the topic indicator selected from the plurality of topic indicators 540 and the sender indicator that was selected from a plurality of sender indicators 550, the notification generator 530 can output the notification 560 including a graphical type of indicator and a graphical sender indicator.
If the notification generator 530 is not able to identify a matching graphical topic indicator from the plurality of topic indicators 540, the notification 560 can be generated using a text-based indicator, such as a term or phrase identified by the message analyzer 520 as the topic that is associated with the message 510. If the notification generator 530 is not able to identify a graphical sender indicator from the plurality of sender indicators 550, a text-based indicator can be utilized, such as all or part of the sender's name.
The system 500 can be implemented by one or more computing devices. In some implementations, the system 500 is implemented by a single computing device, while in other implementations the system 500 is implemented by multiple computing devices. In one implementation, the system 500 is implemented entirely at the message service 130, and the notification 560 is transmitted to the user system 110 and subsequently output for display at the user system 110. In another implementation, the message 510 is received at the user system 110, and the system 500 is implemented entirely at the user system 110. In another implementation, the message 510 is received at the user system 110, the message analyzer 520 is executed at the user system 110, and the notification generator 530 is executed at the message service 130 based on information transmitted to the message service 130 from the user system 110 as a result of execution of the message analyzer 520 at the user system 110. In this implementation, the plurality of topic indicators 540 and the plurality of sender indicators 550 can be located at the message service 130. In another implementation, the notification generator can be implemented in part at the message service 130 and in part at the user system 110. For example, the graphical topic indicator can be identified at the message service 130 using the plurality of topic indicators 540 stored at the message service 130, while the graphical sender indicator is identified by the notification generator 530 executed at the user system 110 with the plurality of sender indicators 550 being stored at the user system 110.
The operations described in connection with the process 800 can be performed at one or more computers, such as at the one or more server computers 132 of the message service 130. When an operation is performed by one or more computers, it is completed when it is performed by one computer. The operations described in connection with the process 800 can be embodied as a non-transitory computer readable storage medium including program instructions executable by one or more processors that, when executed, cause the one or more processors to perform the operations. For example, the operations described in connection with the process 800 could be stored at the memory 220 of a respective one of the server computers 132 and be executable by the CPU 210 thereof.
At operation 810, a message is accessed. A message can be accessed in any suitable manner, such as by receiving the message over a network, retrieving the message from a local memory device, retrieving the message from a remote memory device, retrieving the message from a local storage device, retrieving the message from a remote storage device, by programmatically generating the message, or by any other means in which a message can be made available to a processor, such that the processor is able to perform operations with respect to the message. In one example, a message can be received at the message service 130 from the sender system 120. In another example, the message can be received at the user system 110 from the message service 130.
At operation 820, a least one topic related to the message is identified. The topic related to the message can be identified in any suitable manner. For example, the topic related to the message can be identified in the manner described with respect to the message analyzer 520. In another example, the topic related to the message can be identified by locating, within the message, an explicitly designated topic. The topic related to the message can be identified based on information contained in the message. As one example, identifying the topic related to the message can include semantic analysis of the message.
In operation 830, a graphical topic indicator is identified. In this context, identifying includes any action that will cause a specific graphical topic indicator to be utilized, such as selecting a graphical element as the graphical topic indicator or creating a graphical topic indicator. The graphical topic indicator can be identified based on the at least one topic related to the message, as previously identified in operation 820. In addition, identifying the graphical topic indicator can be performed as described with respect to the notification generator 530.
At operation 840, the sender of the message is identified. In this context, identifying the sender of the message means that a data value is recognized as being descriptive of the identity of the sender. As one example, identifying the sender of a message can include receiving data identifying the sender of the message. As another example, identifying the sender of the message can include analyzing the message to determine, based on the message, the identity of the sender. For example, an email address can be extracted from the message, and compared with previously stored information correlating email addresses to sender identities. As another example, with respect to a text message sent via the SMS protocol, identifying the sender of the message can include receiving a telephone number from which the message originated, and accessing information that correlates the sender identities to telephone numbers. Other methods can be utilized to identify the sender of the message.
At operation 850, a graphical sender indicator is identified. In this context, identifying the graphical sender indicator encompasses any manner in which the graphical sender indicator becomes available for use by the process 800. The graphical sender indicator is identified based on the identity of the sender of the message. As one example, identifying the graphical sender indicator can include comparing the identity of the sender of the message to metadata stored with previously-stored graphical sender indicators. In another example, the graphical sender indicator can be created as needed, for example, based on a previously stored image representing the sender and by manipulating that image in any desired fashion, such as by cropping or compositing. Other examples of identifying a graphical sender indicator are as described previously with respect to the notification generator 530.
At operation 860 a visual notification regarding the message is generated in output. Generating the visual notification can include any manner of creation of data representing the visual notification, accessing a previously-stored visual notification that corresponds to the graphical topic indicator and/or the graphical sender indicator, or transmission of data that represents the visual notification. The visual notification is then output for display, such as at a display screen of a client device. In one example, the visual notification is output for display by transmitting information representing the visual notification from a server computer to a client device. In another example, the visual notification is output for display by transmission of data representing the visual notification from a processor at a client device to a display screen associated with the client device.
In some implementations, one or more of the operations described with respect to the process 800 can be omitted. As one example, operation 830 can be omitted, resulting in the generation of a message notification 900 according to a second example in which a graphical user indicator 910 and a test based topic indicator 920 are displayed within a bounded area 930, as shown in
At operation 1210 a message notification is output, such as described with respect to the message notification 1130 of
At operation 1230, a display time period is started. The display time period can be started at the time when the text related to the message is output for display at operation 1220. The display time period can be a predetermined display time, or can be a time period that is determined based on any relevant criteria.
At operation 1240, the text related to the message is currently being displayed, and a determination is made as to whether a first input is received. The first input can be any many of user input made by any type of user input device, such as a touch at a touch screen, a gesture at a touch screen, a click by a mouse, or a key press at a keyboard. If the first input is received while the text related to the message is displayed, the process proceeds to operation 1250. At operation 1250 a determination is made as to whether a second input is received, where the second input can be in any suitable form as described with respect to the first input at operation 1240. When the second input is received at operation 1250, the process advances to operation 1260 where the text related to the message is removed from display, such as described with respect to
If, at operation 1240, the first input is not received the process advances to operation 1270 where it is determined whether the display time period has ended. If the display time period has not ended the process returns to operation 1240 such that the first input can still be received until the display time period has ended. If, at operation 1270, it is determined that the display time period has ended, the process advances to operation 1260 where the text related to the message is removed from display, as previously noted.
In the process 1200, the visual notification is output for display followed by text related to the message which is displayed for a brief period of time unless the first input is received. If the first input is received, display of the text related to the message is continued until the second input is received.
The foregoing description describes only some exemplary implementations of the described techniques. Other implementations are available. For example, the particular naming of the components, capitalization of terms, the attributes, data structures, or any other programming or structural aspect is not mandatory or significant, and the mechanisms that implement the invention or its features may have different names, formats, or protocols. Further, the system may be implemented via a combination of hardware and software, as described, or entirely in hardware elements. Also, the particular division of functionality between the various system components described herein is merely exemplary, and not mandatory; functions performed by a single system component may instead be performed by multiple components, and functions performed by multiple components may instead performed by a single component.
The words “example” or “exemplary” are used herein to mean serving as an example, instance, or illustration. Any aspect or design described herein as “example’ or “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Rather, use of the words “example” or “exemplary” is intended to present concepts in a concrete fashion. As used in this application, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or.” That is, unless specified otherwise, or clear from context, “X includes A or B” is intended to mean any of the natural inclusive permutations. That is, if X includes A; X includes B; or X includes both A and B, then “X includes A or B” is satisfied under any of the foregoing instances. In addition, the articles “a” and “an” as used in this application and the appended claims should generally be construed to mean “one or more” unless specified otherwise or clear from context to be directed to a singular form. Moreover, use of the term “an embodiment” or “one embodiment” or “an implementation” or “one implementation” throughout is not intended to mean the same embodiment or implementation unless described as such.
The implementations of the computer devices (e.g., clients and servers) described herein can be realized in hardware, software, or any combination thereof. The hardware can include, for example, computers, intellectual property (IP) cores, application-specific integrated circuits (ASICs), programmable logic arrays, optical processors, programmable logic controllers, microcode, microcontrollers, servers, microprocessors, digital signal processors or any other suitable circuit. In the claims, the term “processor” should be understood as encompassing any of the foregoing hardware, either singly or in combination. The terms “signal” and “data” are used interchangeably. Further, portions of each of the clients and each of the servers described herein do not necessarily have to be implemented in the same manner.
Operations that are described as being performed by a single processor, computer, or device can be distributed across a number of different processors, computers or devices. Similarly, operations that are described as being performed by different processors, computers, or devices can, in some cases, be performed by a single processor, computer or device.
Although features may be described above or claimed as acting in certain combinations, one or more features of a combination can in some cases be excised from the combination, and the combination may be directed to a sub-combination or variation of a sub-combination.
The systems described herein, such as client computers and server computers, can be implemented using general purpose computers/processors with a computer program that, when executed, carries out any of the respective methods, algorithms and/or instructions described herein. In addition or alternatively, for example, special purpose computers/processors can be utilized which can contain specialized hardware for carrying out any of the methods, algorithms, or instructions described herein.
Some portions of above description include disclosure presented in terms of algorithms and symbolic representations of operations on information. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. These operations, while described functionally or logically, are understood to be implemented by computer programs. Furthermore, it has also proven convenient at times, to refer to these arrangements of operations as modules or by functional names, without loss of generality. It should be noted that the process steps and instructions of implementations of this disclosure could be embodied in software, firmware or hardware, and when embodied in software, could be downloaded to reside on and be operated from different platforms used by real time network operating systems.
Unless specifically stated otherwise as apparent from the above discussion, it is appreciated that throughout the description, discussions utilizing terms such as “processing” or “computing” or “calculating” or “determining” or “displaying” or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system memories or registers or other such information storage, transmission or display devices.
At least one implementation of this disclosure relates to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored on a computer readable storage medium that can be accessed by the computer.
All or a portion of the embodiments of the disclosure can take the form of a computer program product accessible from, for example, a non-transitory computer-usable or computer-readable medium. The computer program, when executed, can carry out any of the respective techniques, algorithms and/or instructions described herein. A non-transitory computer-usable or computer-readable medium can be any device that can, for example, tangibly contain, store, communicate, or transport the program for use by or in connection with any processor. The non-transitory medium can be, for example, any type of disk including floppy disks, optical disks, CD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for tangibly containing, storing, communicating, or transporting electronic instructions.
It is to be understood that the disclosure is not to be limited to the disclosed embodiments but, on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
4694406 | Shibui et al. | Sep 1987 | A |
4853878 | Brown | Aug 1989 | A |
5038138 | Akiyama et al. | Aug 1991 | A |
5175813 | Golding et al. | Dec 1992 | A |
5317306 | Abraham et al. | May 1994 | A |
5361361 | Hickman et al. | Nov 1994 | A |
5394523 | Harris | Feb 1995 | A |
5398310 | Tchao et al. | Mar 1995 | A |
5506951 | Ishikawa | Apr 1996 | A |
5526480 | Gibson | Jun 1996 | A |
5563996 | Tchao | Oct 1996 | A |
5610828 | Kodosky et al. | Mar 1997 | A |
5623613 | Rowe et al. | Apr 1997 | A |
5732399 | Katiyar et al. | Mar 1998 | A |
5737553 | Bartok | Apr 1998 | A |
5812123 | Rowe et al. | Sep 1998 | A |
5826241 | Stein et al. | Oct 1998 | A |
5870770 | Wolfe | Feb 1999 | A |
5894311 | Jackson | Apr 1999 | A |
5903267 | Fisher | May 1999 | A |
5905863 | Knowles et al. | May 1999 | A |
5948058 | Kudoh et al. | Sep 1999 | A |
5999159 | Isomura | Dec 1999 | A |
5999179 | Kekic et al. | Dec 1999 | A |
6008803 | Rowe et al. | Dec 1999 | A |
6026388 | Liddy et al. | Feb 2000 | A |
6034688 | Greenwood et al. | Mar 2000 | A |
6052121 | Webster et al. | Apr 2000 | A |
6078306 | Lewis | Jun 2000 | A |
6085205 | Peairs et al. | Jul 2000 | A |
6088696 | Moon et al. | Jul 2000 | A |
6154740 | Shah | Nov 2000 | A |
6184881 | Medl | Feb 2001 | B1 |
6246996 | Stein et al. | Jun 2001 | B1 |
6252597 | Lokuge | Jun 2001 | B1 |
6272537 | Kekic et al. | Aug 2001 | B1 |
6289361 | Uchida | Sep 2001 | B1 |
6300967 | Wagner et al. | Oct 2001 | B1 |
6340979 | Beaton et al. | Jan 2002 | B1 |
6348935 | Malacinski et al. | Feb 2002 | B1 |
6380947 | Stead | Apr 2002 | B1 |
6388682 | Kurtzberg et al. | May 2002 | B1 |
6396513 | Helfman et al. | May 2002 | B1 |
6424995 | Shuman | Jul 2002 | B1 |
6442440 | Miller | Aug 2002 | B1 |
6499026 | Rivette et al. | Dec 2002 | B1 |
6529744 | Birkler et al. | Mar 2003 | B1 |
6549218 | Gershony et al. | Apr 2003 | B1 |
6563518 | Gipalo | May 2003 | B1 |
6582474 | LaMarca et al. | Jun 2003 | B2 |
6628996 | Sezaki et al. | Sep 2003 | B1 |
6631398 | Klein | Oct 2003 | B1 |
6640230 | Alexander et al. | Oct 2003 | B1 |
6700591 | Sharpe | Mar 2004 | B1 |
6701346 | Klein | Mar 2004 | B1 |
6738787 | Stead | May 2004 | B2 |
6782393 | Balabanovic et al. | Aug 2004 | B1 |
6980977 | Hoshi et al. | Dec 2005 | B2 |
6990452 | Ostermann et al. | Jan 2006 | B1 |
7003736 | Kanevsky | Feb 2006 | B2 |
7073129 | Robarts et al. | Jul 2006 | B1 |
7107268 | Zawadzki et al. | Sep 2006 | B1 |
7117445 | Berger | Oct 2006 | B2 |
7120646 | Streepy, Jr. | Oct 2006 | B2 |
7127476 | Narahara | Oct 2006 | B2 |
7137074 | Newton et al. | Nov 2006 | B1 |
7139800 | Bellotti et al. | Nov 2006 | B2 |
7209246 | Suda et al. | Apr 2007 | B2 |
7243125 | Newman et al. | Jul 2007 | B2 |
7262772 | Ebert | Aug 2007 | B2 |
7295995 | York et al. | Nov 2007 | B1 |
7320105 | Sinyak et al. | Jan 2008 | B1 |
7395507 | Robarts et al. | Jul 2008 | B2 |
7401131 | Robertson et al. | Jul 2008 | B2 |
7421664 | Wattenberg et al. | Sep 2008 | B2 |
7421690 | Forstall et al. | Sep 2008 | B2 |
7428579 | Libbey, IV et al. | Sep 2008 | B2 |
7441194 | Vronay et al. | Oct 2008 | B2 |
7454716 | Venolia | Nov 2008 | B2 |
7487458 | Jalon et al. | Feb 2009 | B2 |
7505974 | Gropper | Mar 2009 | B2 |
7512901 | Vong et al. | Mar 2009 | B2 |
7523126 | Rivette et al. | Apr 2009 | B2 |
7526559 | Phillips | Apr 2009 | B1 |
7533064 | Boesch | May 2009 | B1 |
7565404 | Gwozdz | Jul 2009 | B2 |
7831834 | Hickman et al. | Nov 2010 | B2 |
7836391 | Tong | Nov 2010 | B2 |
7844906 | Berger | Nov 2010 | B2 |
7904387 | Geering | Mar 2011 | B2 |
7908566 | Wilcox et al. | Mar 2011 | B2 |
7917867 | Wattenberg et al. | Mar 2011 | B2 |
7921176 | Madnani | Apr 2011 | B2 |
8073910 | Tokuda et al. | Dec 2011 | B2 |
8150928 | Fang | Apr 2012 | B2 |
8199899 | Rogers et al. | Jun 2012 | B2 |
8281247 | Daniell et al. | Oct 2012 | B2 |
8310510 | Asahina | Nov 2012 | B2 |
8386914 | Baluja et al. | Feb 2013 | B2 |
8527011 | Bauer et al. | Sep 2013 | B1 |
8726179 | Yerkes et al. | May 2014 | B2 |
8730028 | Putterman | May 2014 | B2 |
8875030 | Loverin et al. | Oct 2014 | B1 |
9143468 | Cohen | Sep 2015 | B1 |
20010044741 | Jacobs et al. | Nov 2001 | A1 |
20020004793 | Keith, Jr. | Jan 2002 | A1 |
20020019827 | Shiman et al. | Feb 2002 | A1 |
20020047868 | Miyazawa | Apr 2002 | A1 |
20020051015 | Matoba | May 2002 | A1 |
20020073112 | Kariya | Jun 2002 | A1 |
20020073157 | Newman et al. | Jun 2002 | A1 |
20020080187 | Lawton | Jun 2002 | A1 |
20020084991 | Harrison et al. | Jul 2002 | A1 |
20020099775 | Gupta et al. | Jul 2002 | A1 |
20020120702 | Schiavone et al. | Aug 2002 | A1 |
20020120858 | Porter et al. | Aug 2002 | A1 |
20020128047 | Gates | Sep 2002 | A1 |
20020138834 | Gerba et al. | Sep 2002 | A1 |
20020174183 | Saeidi | Nov 2002 | A1 |
20020186252 | Himmel et al. | Dec 2002 | A1 |
20020188689 | Michael | Dec 2002 | A1 |
20020194280 | Altavilla et al. | Dec 2002 | A1 |
20030014482 | Toyota et al. | Jan 2003 | A1 |
20030101065 | Rohall et al. | May 2003 | A1 |
20030120719 | Yepishin et al. | Jun 2003 | A1 |
20030120762 | Yepishin et al. | Jun 2003 | A1 |
20030146941 | Bailey et al. | Aug 2003 | A1 |
20030154212 | Schirmer et al. | Aug 2003 | A1 |
20030163537 | Rohall et al. | Aug 2003 | A1 |
20030167310 | Moody et al. | Sep 2003 | A1 |
20030182310 | Charnock et al. | Sep 2003 | A1 |
20030191816 | Landress et al. | Oct 2003 | A1 |
20030195963 | Song et al. | Oct 2003 | A1 |
20030226152 | Billmaier et al. | Dec 2003 | A1 |
20040046776 | Phillips et al. | Mar 2004 | A1 |
20040058673 | Irlam et al. | Mar 2004 | A1 |
20040068544 | Malik et al. | Apr 2004 | A1 |
20040073616 | Fellenstein et al. | Apr 2004 | A1 |
20040243926 | Trenbeath et al. | Dec 2004 | A1 |
20040260756 | Forstall et al. | Dec 2004 | A1 |
20040268265 | Berger | Dec 2004 | A1 |
20050004989 | Satterfield et al. | Jan 2005 | A1 |
20050066037 | Song et al. | Mar 2005 | A1 |
20050108345 | Suzuki | May 2005 | A1 |
20050108351 | Naick et al. | May 2005 | A1 |
20050114753 | Kumar | May 2005 | A1 |
20050144569 | Wilcox et al. | Jun 2005 | A1 |
20050144570 | Loverin et al. | Jun 2005 | A1 |
20050144571 | Loverin et al. | Jun 2005 | A1 |
20050144572 | Wattenberg et al. | Jun 2005 | A1 |
20050149858 | Stern et al. | Jul 2005 | A1 |
20050160158 | Firebaugh et al. | Jul 2005 | A1 |
20050223058 | Buchheit et al. | Oct 2005 | A1 |
20050246420 | Little, II | Nov 2005 | A1 |
20060020548 | Flather | Jan 2006 | A1 |
20060123091 | Ho | Jun 2006 | A1 |
20060200523 | Tokuda et al. | Sep 2006 | A1 |
20060248573 | Pannu et al. | Nov 2006 | A1 |
20060271381 | Pui | Nov 2006 | A1 |
20070150513 | Vanden Heuvel et al. | Jun 2007 | A1 |
20070192423 | Karlson | Aug 2007 | A1 |
20070198343 | Collison et al. | Aug 2007 | A1 |
20070233786 | Rothley | Oct 2007 | A1 |
20080114838 | Taylor | May 2008 | A1 |
20080270935 | Wattenberg et al. | Oct 2008 | A1 |
20090100009 | Karp | Apr 2009 | A1 |
20090132273 | Boesch | May 2009 | A1 |
20090222747 | May et al. | Sep 2009 | A1 |
20090287780 | Gawor et al. | Nov 2009 | A1 |
20100070372 | Watfa et al. | Mar 2010 | A1 |
20100166159 | Katis | Jul 2010 | A1 |
20100274628 | Kunz et al. | Oct 2010 | A1 |
20100306265 | Jones, III | Dec 2010 | A1 |
20110099510 | Wilcox et al. | Apr 2011 | A1 |
20110131207 | Jonsson | Jun 2011 | A1 |
20110137751 | Stein et al. | Jun 2011 | A1 |
20110166939 | Junkin et al. | Jul 2011 | A1 |
20110209159 | Baratz et al. | Aug 2011 | A1 |
20110246361 | Geering | Oct 2011 | A1 |
20110279459 | Hohpe | Nov 2011 | A1 |
20120047460 | McCann | Feb 2012 | A1 |
20120179502 | Farooq et al. | Jul 2012 | A1 |
20120253896 | Killoran, Jr. et al. | Oct 2012 | A1 |
20120253916 | Ayloo | Oct 2012 | A1 |
20120254770 | Ophir | Oct 2012 | A1 |
20120290979 | Devecka | Nov 2012 | A1 |
20130013456 | Boesch | Jan 2013 | A1 |
20130024452 | Defusco et al. | Jan 2013 | A1 |
20130041764 | Donovan et al. | Feb 2013 | A1 |
20130054354 | Kunz et al. | Feb 2013 | A1 |
20130073982 | Abouyounes | Mar 2013 | A1 |
20130174031 | Constantinou | Jul 2013 | A1 |
20130227478 | Rydenhag et al. | Aug 2013 | A1 |
20140012743 | Hanson et al. | Jan 2014 | A1 |
20140143684 | Oh | May 2014 | A1 |
20140172628 | Argue | Jun 2014 | A1 |
20140289258 | Joshi | Sep 2014 | A1 |
Number | Date | Country |
---|---|---|
1194703 | Sep 1998 | CN |
1285557 | Feb 2001 | CN |
1077417 | Feb 2001 | EP |
1232434 | Aug 2002 | EP |
8286871 | Nov 1996 | JP |
09326822 | Dec 1997 | JP |
2001325296 | Nov 2001 | JP |
2003271526 | Sep 2003 | JP |
20020050785 | Jun 2002 | KR |
WO9724684 | Jul 1997 | WO |
WO0123995 | Apr 2001 | WO |
WO2011049399 | Apr 2011 | WO |
Entry |
---|
How to Use Outlook Express, UCLA, Jan. 11, 2008, available at ,http://web.archive.org/web/20080111060000/http://www.bol.ucla.edu/software/win/oe/. |
http://howto.cnet.com/8301-11310_39-57585518-285/how-to-send-money-via-gmail/. |
http://www.google.com/wallet/send-money/. |
Rohall, Steven L., et al., “Email Visualizations to Aid Communications”, IEEE Symposium on Information Visualization, Oct. 22-23, 2001, 5 pages. |
Venolia, Gina, et al., “Understanding Sequence and Reply Relationship within Email Converstations: A Mixed-Model Visualization”, Paper: Intergrating Tools and Tasks, vol. No. 5, Issue No. 1, Ft. Lauderdale, Florida, Apr. 5-10, 2003, pp. 361-368. |
Pamela Parker. “Google Testing Unique AdWords Format Designed for Gmail,” Aug. 18, 2011, Search Engine Land, available at http://web.archive.org/web/20111028150326/http://searchengineland.com/google-testing-unique-adwords-format-designed-for-gmail. |
Jason Comwell, “A preview of Gmails new look,” Jun. 30, 2011, The Official Gmail Blog, available at http://web.archive.org/web/20110703043327/http://gmailblog.blogspot.com/2011/06/preview-of-gmails-new-look-html. |
http://www.ubiq.com/hypertext/weiser/SciAmDraft3.html. |
http://www.johnseelybrown.com/calmtech.pdf. |
http://195.248.77.74/˜saskia/PhDthesis_SaskiaBakker.pdf. |
http://ww.w.journalofvision.org/content/13/2/18.full. |
http://laplab.ucsd.edu/articles/Pashler_AttnVisPerception1995.pdf. |
https://medium.com/something-like-falling/2cd5eac39700. |
Piers Dillon-Scott; “Gmail's new ads are about to invade your inbox”. http://sociable.co/web/now-gmail-is-sending-ads-to-you-kind-of/. May 27, 2012. |