[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

USRE47081E1 - System and method for an extendable mobile communications device user interface - Google Patents

System and method for an extendable mobile communications device user interface Download PDF

Info

Publication number
USRE47081E1
USRE47081E1 US14/298,755 US201414298755A USRE47081E US RE47081 E1 USRE47081 E1 US RE47081E1 US 201414298755 A US201414298755 A US 201414298755A US RE47081 E USRE47081 E US RE47081E
Authority
US
United States
Prior art keywords
mail address
message
controller
mail
application
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
US14/298,755
Inventor
Michael Maguire
Krishna K. Pathiyal
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Malikie Innovations Ltd
Original Assignee
BlackBerry Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by BlackBerry Ltd filed Critical BlackBerry Ltd
Priority to US14/298,755 priority Critical patent/USRE47081E1/en
Assigned to BLACKBERRY LIMITED reassignment BLACKBERRY LIMITED CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: RESEARCH IN MOTION LIMITED
Assigned to RESEARCH IN MOTION LIMITED reassignment RESEARCH IN MOTION LIMITED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MAGUIRE, MICHAEL, PATHIYAL, KRISHNA K.
Application granted granted Critical
Publication of USRE47081E1 publication Critical patent/USRE47081E1/en
Anticipated expiration legal-status Critical
Assigned to MALIKIE INNOVATIONS LIMITED reassignment MALIKIE INNOVATIONS LIMITED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BLACKBERRY LIMITED
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/72522

Definitions

  • This invention relates generally to a software interface for a mobile device. More particularly, the invention provides an extendable software interface enabling forward compatibility in a mobile device, such that new applications may be easily integrated into the mobile device. This invention is particularly well-suited for use in Personal Digital Assistants, mobile communication devices, cellular phones, and wireless two-way email communication devices (collectively referred to herein as “mobile devices”).
  • mobile devices Personal Digital Assistants, mobile communication devices, cellular phones, and wireless two-way email communication devices
  • Typical mobile device interfaces are constrained by resource limitations on the mobile device as compared to those of a desktop system. As a result of these constraints, known mobile device interfaces are generally either hard-wired or hard-coded. In either case, the known mobile device interfaces are immutable once the mobile device has been manufactured. For instance, in a hard-wired mobile device, physical components, such as push buttons and displays, are generally integrated into a user interface by control logic wired into a printed circuit board. Consequently, a hard-wired mobile device is not capable of being upgraded to support new applications. In a hard-coded mobile device, a programmable device is typically used for the control logic, and the user interface is generally controlled by the firmware and/or operating system of the mobile device.
  • New applications can generally be added to a hard-coded mobile device, but this process typically involves replacing or upgrading the interface software, which often involves a risk of breaking compatibility with legacy features of the mobile device.
  • neither hard-wired nor hard-coded mobile devices typically allow a user to seamlessly interface between an application program and data types associated with other application programs.
  • a system and method for an extendable software interface includes a software architecture for use in a mobile device having a processor and a memory device.
  • the software architecture comprises a plurality of application programs stored in the memory device and executed by the processor, and at least one controller module for interfacing the plurality of application programs with a data model configured to interact with a particular type of data object.
  • Each controller module utilizes one or more generic interfaces with the plurality of application programs, and also utilizes a specific interface with the data model.
  • FIG. 1 is a block diagram showing a mobile device with an exemplary extendable software interface
  • FIG. 2 is a block diagram illustrating the interaction between four exemplary controllers and four exemplary data models
  • FIG. 3 is a block diagram illustrating that multiple controllers having generic interfaces can each interact with the same application program
  • FIG. 4 is a block diagram illustrating that controllers are singletons each capable of interfacing with multiple data modules of the same type
  • FIG. 5 is a block diagram illustrating exemplary second-order controllers and second-order data models
  • FIG. 6 is a block diagram showing an alternative embodiment in which second-order objects are accessed with second-order controllers and a first-order data model
  • FIG. 7 illustrates an implementation of the extendable software interface that adds functionality to an e-mail message application
  • FIG. 8 illustrates an implementation of the extendable software interface that adds third-party stock brokerage functions to the e-mail message application.
  • FIG. 9 is a flow diagram showing an exemplary method for adding functionality to an application operating on a mobile device by utilizing the extendable software interface.
  • FIG. 1 is a block diagram showing a mobile device 10 with an exemplary extendable software interface.
  • the mobile device comprises a processor 12 coupled to a system memory 14 , an input device 20 , a display 22 , and a transceiver 24 .
  • an operating system 26 within the system memory 16 is an operating system 26 that includes a virtual machine 28 .
  • the virtual machine 28 operates using two types of software modules, controllers 30 and data models 32 , that interface with application programs 34 through a plurality of generic interfaces 18 .
  • the software interface of the mobile device 10 is extended using the software modules 30 and 32 , and the generic interfaces 18 .
  • the software modules 30 and 32 are executed by the virtual machine 28 , which is preferably an object oriented run-time environment such as Sun Micro System's J2ME (JAVA® 2 Micro Edition).
  • the software modules 30 and 32 are preferably constructed using a JAVA® compiler capable of enforcing a software application interoperation architecture that takes on the form of a collection of compiled classes and objects along with an application programming interface (API).
  • API application programming interface
  • Data models 32 are classes that represent the various types of data stored on the mobile device 10 .
  • the types of data may include, for example, e-mail messages, address book entries, calendar items, tasks, and memos.
  • next-generation mobile devices may store data such as SMS messages, phone call logs, voice mail indicators, WAP requests, multiple e-mail sources, HTML content exchanges, specialized banking services, financial services, field server and customer service offerings, or downloads from corporate databases.
  • the data models 32 are preferably stored on the mobile device 10 in the form of Java objects for execution in the J2ME run time environment.
  • Each data model 32 is designed for a particular type of data object, and includes specialized functions for retrieving information associated with the data type.
  • an e-mail message model may have specialized functions for retrieving the subject of the e-mail object and for retrieving the body of the e-mail object.
  • a calendar entry model may include specialized functions specific to a calendar entry object, such as a function capable of retrieving the duration of an appointment.
  • Each type of data model 32 has an associated controller 30 capable of interacting with the specific functions of the data model 32 type and representing the data model 32 in a uniform way to the rest of the software interface system.
  • the controllers 30 isolate the data models 32 from the generic interfaces 18 , and implement the generic interfaces 18 such that each controller 30 can be easily hosted by any application program 34 that supports the genetic interfaces 18 .
  • the controllers 30 present a common, standard interface to any application 34 ; and each application that supports the generic interfaces 18 is able to interact with any arbitrary controller 30 .
  • an e-mail application using one or more of the generic interfaces 18 can interface with an address book controller to retrieve an e-mail address from an address book data model.
  • controllers 30 can be used to interface with any new applications supporting the generic interfaces 18 . In this manner, a mobile device user is able to install new applications without having to upgrade his or her operating system 26 or interface software 28 .
  • the flexibility provided by the interoperability of the controllers 30 may also enable the mobile device user to expand the functionality of his or her mobile device 10 by interacting with third party applications, such as banking or other commercial services.
  • each controller 30 The interaction between an application program 34 and any arbitrary controller 30 is primarily made possible by generic interfaces 18 that are implemented each controller 30 .
  • the generic interfaces 18 are generic in the sense that they are object-oriented as opposed to being specific to a certain type of data. Put another way, each generic interface 18 is preferably programmed to perform a certain operation regardless of the data type.
  • each application 34 is preferably programmed to query any controller 30 to determine if the controller 30 supports one or more generic interfaces 18 required to perform a given operation. If so, the application 34 then interacts with the controller 30 and its associated data model 32 to complete the operation.
  • an application 34 may query a controller 30 to determine whether it supports a generic interface 18 capable of painting an object (such as the body of an e-mail message) onto a screen, and if so, then interface with an controller 30 to display the object.
  • a generic interface 18 capable of painting an object (such as the body of an e-mail message) onto a screen
  • the same type of generic interface 18 that is used by an application 34 to display the body of an e-mail message could also be used, for example, to display a clipping from a lengthy SMS message.
  • the same generic interface 18 used to display the e-mail message may also be used to receive an e-mail address from an e-mail controller and interface with an address book application to paint the address into an address file.
  • new controllers could also be implemented that support new generic interfaces. Therefore, new controllers can easily be designed to interface With upgraded applications supporting new functions, and still be compatible with older applications as long as the new controller includes the older generic interfaces.
  • PaintProvider ⁇ void paint(Object model, Graphics g, int x, int y, int Width, int height, Object context); ⁇
  • FieldProvider ⁇ Field getField(Object model, Object context) throws NoFieldException; void grabDataFromField(Object model, Field field); ⁇
  • VerbProvider ⁇ Verb [ ] getVerbs(Object model, Object context); Verb [ ] getDefaultVerb(Object model, Object context); ⁇
  • FIG. 2 is a block diagram 40 illustrating the interaction between four exemplary controllers 42 , 44 , 46 and 48 , and four exemplary data models 52 , 54 , 56 and 58 .
  • the exemplary controllers shown in the diagram 40 include an e-mail message controller 42 , an SMS message controller 44 , an address book card controller 46 , and a calendar entry controller 48 .
  • Each exemplary controller 42 , 44 , 46 , and 48 is unique to a data model type; respectively shown in the diagram 40 as an e-mail message 52 , a SMS message 54 , an address book card 56 , and a calendar entry 58 .
  • each exemplary controller 42 , 44 , 46 , and 48 includes three generic interfaces: Interface A 60 , Interface B 62 , and Interface C 64 .
  • Interface A 60 interface A 60
  • Interface B 62 interface B
  • Interface C 64 interface C 64 .
  • every controller 42 , 44 , 46 , and 48 is unique to a data model 52 , 54 , 56 , and 58
  • the same generic interfaces 60 , 62 and 64 are implemented universally throughout the software interface. Therefore, as discussed above with reference to FIG. 1 , each exemplary controller 42 , 44 , 46 , and 48 is able to interface with any application program that supports the generic interfaces 60 , 62 and 64 .
  • FIG. 3 is a block diagram 70 illustrating that multiple controllers 72 , 74 , 76 and 78 having generic interfaces 80 , 82 , and 84 can each interact with the same application program 86 .
  • FIG. 3 shows an e-mail message controller 72 , an SMS message controller 74 , a voice mail indicator controller 76 , and a third-party supplied controller 78 .
  • Each controller 72 , 74 , 76 and 78 includes the same three generic interfaces 80 , 82 and 84 , and thus all four controllers 72 , 74 , 76 and 78 are able to interact with the same application 86 .
  • the interface software 28 remains consistent regardless of the data type being accessed.
  • FIG. 3 demonstrates that a third-party may easily design a new controller 78 that is compatible with the existing software interface system by including the generic interfaces 80 , 82 and 84 supported by the application program 86 and other applications on the system.
  • FIG. 4 is a block diagram 90 illustrating that controllers 92 , 94 , and 96 are singletons each capable of interfacing with multiple data models of the same type.
  • controllers 92 , 94 , and 96 are singletons each capable of interfacing with multiple data models of the same type.
  • the persisted list should preferably identify a data model for each data object in the list. Since the same type of data model may often be associated with multiple data objects in the list, multiple instances of various data model software modules could be executing in the system at the same time. This is illustrated in FIG. 4 by the multiple instances of the e-mail message data models 98 and 100 , the SMS message data models 102 and 104 , and the voice mail indicator data models 106 and 108 .
  • the persisted list should not identify a controller 92 , 94 or 96 for each data object. Rather, the appropriate controller 92 , 94 or 96 is preferably identified as some action is taken with a data model 98 , 100 , 102 , 104 , 106 or 108 .
  • the application 34 preferably (1) queries the data model for the correct controller, (2) calls the controller, and then (3) passes in the data model as the first parameter.
  • the controllers 92 , 94 and 96 are stateless objects such that only one instance of a controller 92 , 94 or 96 is capable of handling all of the data models of a certain type that are executing in the system. For example, in FIG. 4 one instance of an e-mail message controller 92 interfaces with both instances of the e-mail message data model 98 and 100 .
  • FIG. 5 is a block diagram 200 illustrating exemplary second-order controllers 210 , 212 and 214 and second-order data models 218 , 220 and 222 .
  • the controllers and data models illustrated in FIGS. 2-3 are examples of software modules designed to interface with first order objects, such as an e-mail message, an address book entry or a calendar item.
  • the extendable software interface is also capable of interfacing with multiple objects within a first-order object, referred to herein as second-order objects.
  • An example of a second-order object is an address that appears within the body of an e-mail message.
  • the extendable software interface preferably utilizes second-order controllers that operate within a first-order controller.
  • FIG. 5 shows four second-order controllers 210 , 212 and 214 within an e-mail message controller 226 .
  • Each of the second-order controllers 210 , 212 and 214 are preferably programmed to access a particular type of second-order object.
  • FIG. 5 shows one exemplary method by which a second-order controller may access a second-order object.
  • a second-order data model 218 , 220 or 222 is created for each type of second-order object.
  • the second-order data models 218 , 220 and 222 preferably operate within a first-order data model 228 .
  • each second-order data model 218 , 220 or 222 is programmed to access a particular type of information within a data type, thus enabling a second-order object to be manipulated by an application program 34 through the second-order controllers 210 , 212 and 214 . Examples illustrating the manipulation of second-order objects are detailed below with reference to FIGS. 7 and 8 .
  • FIG. 6 is a block diagram showing an alternative embodiment 300 in which second-order objects are accessed with second-order controllers 302 , 304 and 306 and a first-order data model 310 .
  • the first-order data object is grouped by the virtual machine 28 in such a way that second-order data objects can be identified from within the first-order data model 310 . This may be accomplished, for example, by grouping a first order data object that includes multiple second-order data objects such that they appear to the system as essentially one immutable object.
  • each of the sub-pieces (second-order objects) of the group can be independently accessed.
  • the second-order controllers 302 , 304 and 306 are then programmed to identify the second-order data objects from within the data object grouping. In this manner, memory space on the system can be better utilized by eliminating the need for second-order data models.
  • FIG. 7 illustrates an implementation of the extendable software interface that adds functionality to an e-mail message application.
  • any e-mail addresses that appear in any portion of an e-mail message 400 are action-linked. This may be accomplished, for example, by designing an e-mail message controller capable of (1) recognizing e-mail addresses as second-order objects, and (2) delegating the interface between the e-mail message application and the e-mail address to an object-specific, second-order e-mail address controller operating within the e-mail controller.
  • the e-mail address controller should preferably be capable of retrieving e-mail addresses 410 from a first-order e-mail message model.
  • specialized second-order e-mail address models may be constructed to operate within the e-mail message model and interact with the e-mail address controller.
  • e-mail addresses 410 as second-order objects, and designing interface software modules capable of retrieving the addresses 410 from within any portion of an e-mail message 400 , an existing e-mail application is extended such that it can perform previously unavailable operations.
  • the e-mail message controller when a mobile device user positions a cursor in the vicinity of the e-mail address “ulf@bigcompany.com” 410 , the e-mail message controller preferably recognizes that the address 410 is a second-order object and calls the specialized second-order e-mail address controller.
  • the e-mail address controller then preferably presents a list of functions 412 on a display of the device that can be performed on the e-mail address 410 .
  • the function list 412 may preferably include operations involving other applications.
  • the function “Add Ulf to address book” may require the e-mail address controller to interface with an address book application. This seamless operation is possible because the generic interfaces enable the e-mail address controller to interface with any application within the system.
  • FIG. 8 illustrates an implementation of the extendable software interface that adds third-party stock brokerage functions 500 to the e-mail message application.
  • an e-mail message 510 sent from a stock broker includes action-linked stock quotations 512 .
  • the mobile device manufacturer, or preferably the third party may design an e-mail message controller upgrade that adds second-order controllers that are specific to data objects typically found in an e-mail from a stock broker.
  • the upgraded e-mail controller when a user positions a cursor in the vicinity of a stock quote or ticker symbol 512 in the e-mail message 510 , the upgraded e-mail controller preferably (1) recognizes the quote or symbol 512 as a second-order object and (2) calls the object-specific second-order controller. The second-order controller then preferably presents a list of functions 500 to the e-mail message application that are capable of being performed on the object 512 .
  • the available functions are “SELL,” BUY,” “Request more info,” and “Cancel.”
  • the second-order controller may be programmed to (1) instruct the e-mail application to create a new e-mail message, (2) paint the address “stocks@tdbank.com” into the receiver line (the “To:” line) of the new message, (3) paint the address “MGeek@rim.net” into the sender line (the “From:” line) of the new message, and (4) paint the text “SELL” along with the second-order object “ALCN. TO 12.33-122.21” into the body portion of the new message.
  • the extendable software interface preferably enables additional functionality to be added to an existing application with only a simple upgrade to the application's controller.
  • FIG. 9 is a flow diagram showing an exemplary method 600 for adding functionality to an application operating on a mobile device by utilizing the extendable software interface.
  • step 610 one or more second-order objects are defined within the first-order data model associated with the application. For instance, in an e-mail message data model, second-order objects may be defined as described above with reference to FIGS. 7 and 8 . It should be understood, however, that this method 600 is not limited to an e-mail messaging application, but may be utilized with any application operating on a mobile device.
  • the application data model containing the second-order objects is displayed by the application. As discussed above with reference to FIG. 1 , the data model is preferably accessed by the application through generic interfaces and a first-order controller.
  • a mobile device user may preferably select a second-order object by positioning a cursor on, or in the vicinity of, the second-order object (step 630 ).
  • the second-order object may be selected by any other means available on the mobile device, such as highlighting the object or touching the object with a stylus.
  • the first-order controller preferably (1) recognizes the object as a second-order object, and (2) calls a second-order controller that is specifically designed to access the second-order object (step 640 ).
  • the second-order controller preferably provides a list of functions that may be performed on the second-order object.
  • the second-order controller preferably establishes whether the function (1) relates to the current application, or (2) requires access to another application installed on the mobile device (step 670 ). For instance, if an address is selected as a second-order object within an e-mail message, then the user may be given the option to (1) insert the address into the “To:” line of a new message, or (2) insert the address into an address book.
  • the second-order (address) controller preferably knows that the selected operation relates to the e-mail messaging application that is already executing. Then, the first and second-order controllers may interface with the currently executing application to perform the selected function (step 700 ). If, however, the user chooses to insert the object into an address book file, then the e-mail message controller and second-order address controller need access to an address book application before the function can be completed. Therefore, when another application installed on the mobile device is required to perform the selected function, the new application is preferably launched by either the first or second-order controller (step 680 ). Then, because the first and second-order applications utilize generic interfaces, both can interface with the new application to perform the selected function (steps 690 and 700 ).

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)
  • Telephone Function (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

A system and method for an extendable software interface includes software architecture for use in a mobile device having a processor and a memory device. The software architecture includes a set of first-order controller software instructions configured to interface the application program with a first-order data model, and a first-order data object stored in the memory device in the form of the first-order data model. The first-order data object includes a second-order data object. A second-order set of controller software instructions configured to interact with the second-order data object is also included in the software architecture.

Description

CROSS-REFERENCE TO RELATED APPLICATIONS
This application is a continuation of U.S. patent application Ser. No. 12/887,758, filed on Sep. 22, 2010, which is a continuation of U.S. patent application Ser. No. 11/237,010, filed on Sep. 28, 2005, (now U.S. Pat. No. 7,805,729), which is a continuation of U.S. patent application Ser. No. 09/897,207, filed on Jul. 2, 2001, (now U.S. Pat. No. 6,990,672), which claimed priority from U.S. Provisional Application No. 60/215,605, filed Jun. 30, 2000. These prior applications, including their entire written descriptions and drawing figures, are hereby incorporated into the present application by reference.
BACKGROUND
1. Field of the Invention
This invention relates generally to a software interface for a mobile device. More particularly, the invention provides an extendable software interface enabling forward compatibility in a mobile device, such that new applications may be easily integrated into the mobile device. This invention is particularly well-suited for use in Personal Digital Assistants, mobile communication devices, cellular phones, and wireless two-way email communication devices (collectively referred to herein as “mobile devices”).
2. Description of the Related Art
Typical mobile device interfaces are constrained by resource limitations on the mobile device as compared to those of a desktop system. As a result of these constraints, known mobile device interfaces are generally either hard-wired or hard-coded. In either case, the known mobile device interfaces are immutable once the mobile device has been manufactured. For instance, in a hard-wired mobile device, physical components, such as push buttons and displays, are generally integrated into a user interface by control logic wired into a printed circuit board. Consequently, a hard-wired mobile device is not capable of being upgraded to support new applications. In a hard-coded mobile device, a programmable device is typically used for the control logic, and the user interface is generally controlled by the firmware and/or operating system of the mobile device. New applications can generally be added to a hard-coded mobile device, but this process typically involves replacing or upgrading the interface software, which often involves a risk of breaking compatibility with legacy features of the mobile device. In addition, neither hard-wired nor hard-coded mobile devices typically allow a user to seamlessly interface between an application program and data types associated with other application programs.
SUMMARY
A system and method for an extendable software interface includes a software architecture for use in a mobile device having a processor and a memory device. The software architecture comprises a plurality of application programs stored in the memory device and executed by the processor, and at least one controller module for interfacing the plurality of application programs with a data model configured to interact with a particular type of data object. Each controller module utilizes one or more generic interfaces with the plurality of application programs, and also utilizes a specific interface with the data model.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram showing a mobile device with an exemplary extendable software interface;
FIG. 2 is a block diagram illustrating the interaction between four exemplary controllers and four exemplary data models;
FIG. 3 is a block diagram illustrating that multiple controllers having generic interfaces can each interact with the same application program;
FIG. 4 is a block diagram illustrating that controllers are singletons each capable of interfacing with multiple data modules of the same type;
FIG. 5 is a block diagram illustrating exemplary second-order controllers and second-order data models;
FIG. 6 is a block diagram showing an alternative embodiment in which second-order objects are accessed with second-order controllers and a first-order data model;
FIG. 7 illustrates an implementation of the extendable software interface that adds functionality to an e-mail message application;
FIG. 8 illustrates an implementation of the extendable software interface that adds third-party stock brokerage functions to the e-mail message application; and
FIG. 9 is a flow diagram showing an exemplary method for adding functionality to an application operating on a mobile device by utilizing the extendable software interface.
DETAILED DESCRIPTION
Referring now to the drawing figures, FIG. 1 is a block diagram showing a mobile device 10 with an exemplary extendable software interface. The mobile device comprises a processor 12 coupled to a system memory 14, an input device 20, a display 22, and a transceiver 24. Within the system memory 16 is an operating system 26 that includes a virtual machine 28. The virtual machine 28 operates using two types of software modules, controllers 30 and data models 32, that interface with application programs 34 through a plurality of generic interfaces 18.
Operationally, the software interface of the mobile device 10 is extended using the software modules 30 and 32, and the generic interfaces 18. The software modules 30 and 32 are executed by the virtual machine 28, which is preferably an object oriented run-time environment such as Sun Micro System's J2ME (JAVA® 2 Micro Edition). The software modules 30 and 32 are preferably constructed using a JAVA® compiler capable of enforcing a software application interoperation architecture that takes on the form of a collection of compiled classes and objects along with an application programming interface (API).
Data models 32 are classes that represent the various types of data stored on the mobile device 10. The types of data may include, for example, e-mail messages, address book entries, calendar items, tasks, and memos. In addition, next-generation mobile devices may store data such as SMS messages, phone call logs, voice mail indicators, WAP requests, multiple e-mail sources, HTML content exchanges, specialized banking services, financial services, field server and customer service offerings, or downloads from corporate databases.
The data models 32 are preferably stored on the mobile device 10 in the form of Java objects for execution in the J2ME run time environment. Each data model 32 is designed for a particular type of data object, and includes specialized functions for retrieving information associated with the data type. For example, an e-mail message model may have specialized functions for retrieving the subject of the e-mail object and for retrieving the body of the e-mail object. A calendar entry model, on the other hand, may include specialized functions specific to a calendar entry object, such as a function capable of retrieving the duration of an appointment.
Each type of data model 32 has an associated controller 30 capable of interacting with the specific functions of the data model 32 type and representing the data model 32 in a uniform way to the rest of the software interface system. Operationally, the controllers 30 isolate the data models 32 from the generic interfaces 18, and implement the generic interfaces 18 such that each controller 30 can be easily hosted by any application program 34 that supports the genetic interfaces 18. In this manner, the controllers 30 present a common, standard interface to any application 34; and each application that supports the generic interfaces 18 is able to interact with any arbitrary controller 30. For example, an e-mail application using one or more of the generic interfaces 18 can interface with an address book controller to retrieve an e-mail address from an address book data model. Moreover, existing controllers 30 can be used to interface with any new applications supporting the generic interfaces 18. In this manner, a mobile device user is able to install new applications without having to upgrade his or her operating system 26 or interface software 28. The flexibility provided by the interoperability of the controllers 30 may also enable the mobile device user to expand the functionality of his or her mobile device 10 by interacting with third party applications, such as banking or other commercial services.
The interaction between an application program 34 and any arbitrary controller 30 is primarily made possible by generic interfaces 18 that are implemented each controller 30. The generic interfaces 18 are generic in the sense that they are object-oriented as opposed to being specific to a certain type of data. Put another way, each generic interface 18 is preferably programmed to perform a certain operation regardless of the data type. Operationally, each application 34 is preferably programmed to query any controller 30 to determine if the controller 30 supports one or more generic interfaces 18 required to perform a given operation. If so, the application 34 then interacts with the controller 30 and its associated data model 32 to complete the operation. For instance, an application 34 may query a controller 30 to determine whether it supports a generic interface 18 capable of painting an object (such as the body of an e-mail message) onto a screen, and if so, then interface with an controller 30 to display the object. In this manner, the same type of generic interface 18 that is used by an application 34 to display the body of an e-mail message could also be used, for example, to display a clipping from a lengthy SMS message. In another example, the same generic interface 18 used to display the e-mail message may also be used to receive an e-mail address from an e-mail controller and interface with an address book application to paint the address into an address file. Preferably, new controllers could also be implemented that support new generic interfaces. Therefore, new controllers can easily be designed to interface With upgraded applications supporting new functions, and still be compatible with older applications as long as the new controller includes the older generic interfaces.
Three exemplary generic interfaces that may be implemented by a controller 30 are briefly described below. It should be understood, however, that these are just a few examples of the many types of generic interfaces that could be used within the system shown in FIG. 1.
  • 1. PaintProvider—The Paint Provider interface supports painting a data model 32 into a given region of an application program 34. For example, this generic interface 18 could be used to instruct a controller to paint a data model into a list view. The PaintProvider interface may be implemented as follows:
public interface PaintProvider
{
  void paint(Object model, Graphics g, int x, int y,
  int Width, int height, Object context);
}
  • 2. FieldProvider TheFieldProvider interface enables a controller 30 to provide an application program 34 with a read-only or editable field from a data model 32. For instance, the FieldProvider interface may enable a data model 32 to be displayed in a list of fields, such as in the edit screen of an email message. The FieldProvider interface may be implemented as follows:
public interface FieldProvider
{
  Field getField(Object model, Object context) throws
   NoFieldException;
  void grabDataFromField(Object model, Field field);
}
  • 3. VerbProvider—The VerbProvider interface enables a controller 30 to supply an array of “verbs” when a user selects an object associated with a data model 32. For instance, when a user positions a cursor over an object (such as a portion of text) associated with a particular data model, the VerbProvider interface may display a list of menu selections specific to that data model. The VerbProvider interface may be implemented as follows:
public interface VerbProvider
{
Verb [ ] getVerbs(Object model, Object context);
Verb [ ] getDefaultVerb(Object model, Object context);
}
FIG. 2 is a block diagram 40 illustrating the interaction between four exemplary controllers 42, 44, 46 and 48, and four exemplary data models 52, 54, 56 and 58. The exemplary controllers shown in the diagram 40 include an e-mail message controller 42, an SMS message controller 44, an address book card controller 46, and a calendar entry controller 48. Each exemplary controller 42, 44, 46, and 48 is unique to a data model type; respectively shown in the diagram 40 as an e-mail message 52, a SMS message 54, an address book card 56, and a calendar entry 58. The uniqueness of the controllers and their corresponding data models is illustrated by the varying shapes at the interface between each exemplary controller 42, 44, 46, and 48 and data model 52, 54, 56, and 58. In addition, each exemplary controller 42, 44, 46, and 48 includes three generic interfaces: Interface A 60, Interface B 62, and Interface C 64. Although every controller 42, 44, 46, and 48 is unique to a data model 52, 54, 56, and 58, the same generic interfaces 60, 62 and 64 are implemented universally throughout the software interface. Therefore, as discussed above with reference to FIG. 1, each exemplary controller 42, 44, 46, and 48 is able to interface with any application program that supports the generic interfaces 60, 62 and 64.
FIG. 3 is a block diagram 70 illustrating that multiple controllers 72, 74, 76 and 78 having generic interfaces 80, 82, and 84 can each interact with the same application program 86. For example, FIG. 3 shows an e-mail message controller 72, an SMS message controller 74, a voice mail indicator controller 76, and a third-party supplied controller 78. Each controller 72, 74, 76 and 78 includes the same three generic interfaces 80, 82 and 84, and thus all four controllers 72, 74, 76 and 78 are able to interact with the same application 86. In this manner, the interface software 28 remains consistent regardless of the data type being accessed. In addition, FIG. 3 demonstrates that a third-party may easily design a new controller 78 that is compatible with the existing software interface system by including the generic interfaces 80, 82 and 84 supported by the application program 86 and other applications on the system.
FIG. 4 is a block diagram 90 illustrating that controllers 92, 94, and 96 are singletons each capable of interfacing with multiple data models of the same type. As data entries or messages are received into the system, they are preferably entered into a persisted list of data objects that is included in, or assessable to, each application program 34. The persisted list should preferably identify a data model for each data object in the list. Since the same type of data model may often be associated with multiple data objects in the list, multiple instances of various data model software modules could be executing in the system at the same time. This is illustrated in FIG. 4 by the multiple instances of the e-mail message data models 98 and 100, the SMS message data models 102 and 104, and the voice mail indicator data models 106 and 108.
In a preferred embodiment, however, the persisted list should not identify a controller 92, 94 or 96 for each data object. Rather, the appropriate controller 92, 94 or 96 is preferably identified as some action is taken with a data model 98, 100, 102, 104, 106 or 108. When an application 34 needs to access a data model, the application 34 preferably (1) queries the data model for the correct controller, (2) calls the controller, and then (3) passes in the data model as the first parameter. In this manner, the controllers 92, 94 and 96 are stateless objects such that only one instance of a controller 92, 94 or 96 is capable of handling all of the data models of a certain type that are executing in the system. For example, in FIG. 4 one instance of an e-mail message controller 92 interfaces with both instances of the e-mail message data model 98 and 100.
FIG. 5 is a block diagram 200 illustrating exemplary second- order controllers 210, 212 and 214 and second- order data models 218, 220 and 222. The controllers and data models illustrated in FIGS. 2-3 are examples of software modules designed to interface with first order objects, such as an e-mail message, an address book entry or a calendar item. In a preferred embodiment, however, the extendable software interface is also capable of interfacing with multiple objects within a first-order object, referred to herein as second-order objects. An example of a second-order object is an address that appears within the body of an e-mail message. In order to interface with a second-order object, the extendable software interface preferably utilizes second-order controllers that operate within a first-order controller. For instance, in FIG. 5 four second- order controllers 210, 212 and 214 are shown within an e-mail message controller 226. Each of the second- order controllers 210, 212 and 214 are preferably programmed to access a particular type of second-order object. FIG. 5 shows one exemplary method by which a second-order controller may access a second-order object. In this embodiment, a second- order data model 218, 220 or 222 is created for each type of second-order object. The second- order data models 218, 220 and 222 preferably operate within a first-order data model 228. In this manner, each second- order data model 218, 220 or 222 is programmed to access a particular type of information within a data type, thus enabling a second-order object to be manipulated by an application program 34 through the second- order controllers 210, 212 and 214. Examples illustrating the manipulation of second-order objects are detailed below with reference to FIGS. 7 and 8.
FIG. 6 is a block diagram showing an alternative embodiment 300 in which second-order objects are accessed with second- order controllers 302, 304 and 306 and a first-order data model 310. In this embodiment, the first-order data object is grouped by the virtual machine 28 in such a way that second-order data objects can be identified from within the first-order data model 310. This may be accomplished, for example, by grouping a first order data object that includes multiple second-order data objects such that they appear to the system as essentially one immutable object. When the group is accessed by the virtual machine 28, however, each of the sub-pieces (second-order objects) of the group can be independently accessed. The second- order controllers 302, 304 and 306 are then programmed to identify the second-order data objects from within the data object grouping. In this manner, memory space on the system can be better utilized by eliminating the need for second-order data models.
FIG. 7 illustrates an implementation of the extendable software interface that adds functionality to an e-mail message application. In the embodiment shown in FIG. 7, any e-mail addresses that appear in any portion of an e-mail message 400 are action-linked. This may be accomplished, for example, by designing an e-mail message controller capable of (1) recognizing e-mail addresses as second-order objects, and (2) delegating the interface between the e-mail message application and the e-mail address to an object-specific, second-order e-mail address controller operating within the e-mail controller. The e-mail address controller should preferably be capable of retrieving e-mail addresses 410 from a first-order e-mail message model. Alternatively, specialized second-order e-mail address models may be constructed to operate within the e-mail message model and interact with the e-mail address controller. In either case, by defining e-mail addresses 410 as second-order objects, and designing interface software modules capable of retrieving the addresses 410 from within any portion of an e-mail message 400, an existing e-mail application is extended such that it can perform previously unavailable operations.
For instance, with reference to FIG. 7, when a mobile device user positions a cursor in the vicinity of the e-mail address “ulf@bigcompany.com” 410, the e-mail message controller preferably recognizes that the address 410 is a second-order object and calls the specialized second-order e-mail address controller. Through one of the generic interfaces, the e-mail address controller then preferably presents a list of functions 412 on a display of the device that can be performed on the e-mail address 410. In addition, the function list 412 may preferably include operations involving other applications. For example, the function “Add Ulf to address book” may require the e-mail address controller to interface with an address book application. This seamless operation is possible because the generic interfaces enable the e-mail address controller to interface with any application within the system.
FIG. 8 illustrates an implementation of the extendable software interface that adds third-party stock brokerage functions 500 to the e-mail message application. In this example, an e-mail message 510 sent from a stock broker includes action-linked stock quotations 512. In order to implement this example, the mobile device manufacturer, or preferably the third party, may design an e-mail message controller upgrade that adds second-order controllers that are specific to data objects typically found in an e-mail from a stock broker. With reference to the illustration, when a user positions a cursor in the vicinity of a stock quote or ticker symbol 512 in the e-mail message 510, the upgraded e-mail controller preferably (1) recognizes the quote or symbol 512 as a second-order object and (2) calls the object-specific second-order controller. The second-order controller then preferably presents a list of functions 500 to the e-mail message application that are capable of being performed on the object 512. In this example, the available functions are “SELL,” BUY,” “Request more info,” and “Cancel.” lf, for example, the user selects the “SELL” function from the list 500, then the second-order controller may be programmed to (1) instruct the e-mail application to create a new e-mail message, (2) paint the address “stocks@tdbank.com” into the receiver line (the “To:” line) of the new message, (3) paint the address “MGeek@rim.net” into the sender line (the “From:” line) of the new message, and (4) paint the text “SELL” along with the second-order object “ALCN. TO 12.33-122.21” into the body portion of the new message. Significantly, none of these steps require an upgrade to the e-mail message application. Rather, the extendable software interface preferably enables additional functionality to be added to an existing application with only a simple upgrade to the application's controller.
FIG. 9 is a flow diagram showing an exemplary method 600 for adding functionality to an application operating on a mobile device by utilizing the extendable software interface. In step 610, one or more second-order objects are defined within the first-order data model associated with the application. For instance, in an e-mail message data model, second-order objects may be defined as described above with reference to FIGS. 7 and 8. It should be understood, however, that this method 600 is not limited to an e-mail messaging application, but may be utilized with any application operating on a mobile device. In step 620, the application data model containing the second-order objects is displayed by the application. As discussed above with reference to FIG. 1, the data model is preferably accessed by the application through generic interfaces and a first-order controller. Once the data is displayed, a mobile device user may preferably select a second-order object by positioning a cursor on, or in the vicinity of, the second-order object (step 630). Alternatively, the second-order object may be selected by any other means available on the mobile device, such as highlighting the object or touching the object with a stylus. When a second-order object is selected by the user, the first-order controller preferably (1) recognizes the object as a second-order object, and (2) calls a second-order controller that is specifically designed to access the second-order object (step 640).
In step 650, the second-order controller preferably provides a list of functions that may be performed on the second-order object. Once a function associated with a second-order object has been selected by the mobile device user (step 660), the second-order controller preferably establishes whether the function (1) relates to the current application, or (2) requires access to another application installed on the mobile device (step 670). For instance, if an address is selected as a second-order object within an e-mail message, then the user may be given the option to (1) insert the address into the “To:” line of a new message, or (2) insert the address into an address book. If the user chooses to compose a new message using the selected address in the “To:” line, then the second-order (address) controller preferably knows that the selected operation relates to the e-mail messaging application that is already executing. Then, the first and second-order controllers may interface with the currently executing application to perform the selected function (step 700). If, however, the user chooses to insert the object into an address book file, then the e-mail message controller and second-order address controller need access to an address book application before the function can be completed. Therefore, when another application installed on the mobile device is required to perform the selected function, the new application is preferably launched by either the first or second-order controller (step 680). Then, because the first and second-order applications utilize generic interfaces, both can interface with the new application to perform the selected function (steps 690 and 700).
The embodiments described herein are examples of structures, systems or methods having elements corresponding to the elements of the invention recited in the claims. This written description may enable those skilled in the art to make and use embodiments having alternative elements that likewise correspond to the elements of the invention recited in the claims. The intended scope of the invention thus includes other structures, systems or methods that do not differ from the literal language of the claims, and further includes other structures, systems or methods with insubstantial differences from the literal language of the claims.

Claims (20)

What is claimed:
1. A method of operating a mobile device having a display, comprising:
receiving at the mobile device an electronic a short message service (SMS) message having a body, with an e-mail address within the body;
displaying on the display at least a portion of the electronic SMS message including the e-mail address, wherein the portion of the SMS message is displayed in a first application operating on the mobile device; and
determining, by a message controller at the mobile device, that the SMS message includes the e-mail address, wherein the message controller is associated with an SMS data model, and the SMS data model includes a retrieving function for retrieving the e-mail address from the SMS message;
after determining that the SMS message includes the e-mail address, determining that a cursor is effected near the displayed e-mail address;
in response to a selection of the displayed e-mail address, determining that the cursor is effected near the displayed e-mail address, activating, by the message controller, an e-mail address controller, wherein the e-mail address controller is different than the message controller, the e-mail address controller is associated with an e-mail address data model, wherein the e-mail address data model is associated with at least two functions to be performed on the e-mail address, and the e-mail address controller is configured to display the at least two functions;
displaying, by the e-mail address controller at the mobile device, on the display an a first interface for selecting one of including the at least adding the e-mail address to an address book and creating an e-mail message addressed to the e-mail address two functions to be performed on the e-mail address, wherein the at least two functions include a first function executed by a second application and a second function executed by a third application different than the first and second applications;
receiving, from the first interface, a selection of the first function executed by the second application;
launching, by the e-mail address controller, the second application;
retrieving, by the message controller using the SMS data model, the e-mail address from the SMS message; and
providing, by the message controller, the retrieved e-mail address to the second application.
2. The method of claim 1, wherein the electronic message is an e-mail message.
3. The method of claim 1, wherein the electronic message is an SMS message.
4. The method of claim 1, wherein the receiving at the mobile device the selection of the e-mail address comprises receiving a cursor positioning over the e-mail address.
5. The method of claim 1, further comprising receiving selection of one of the at least adding the e-mail address to the address book and creating the e-mail message addressed to the e-mail address.
6. The method of claim 5 1, further comprising:
after launching an the second application associated with the selection; and
displaying a second interface different than the first interface.
7. The method of claim 1, wherein the first interface comprises a menu list.
8. A mobile communication device, comprising:
a display;
an input device; and
a processor, connected to the display and the input device, and configured to:
receive an electronic a short message service (SMS) message having a body, with an e-mail address within the body,
display on the display at least a portion of the electronic SMS message including the e-mail address, wherein the portion of the SMS message is displayed in a first application operating on the mobile communication device, and
determine, by a message controller at the mobile communication device, that the SMS message includes the e-mail address, wherein the message controller is associated with an SMS data model, and the SMS data model includes a retrieving function for retrieving the e-mail address from the SMS message;
after determining that the SMS message includes the e-mail address, determine that a cursor is effected near the displayed e-mail address;
in response to a selection of the displayed e-mail address at the input device determining that the cursor is near the displayed e-mail address, activate, by the message controller, an e-mail address controller, wherein the e-mail address controller is different than the message controller, the e-mail address controller is associated with an e-mail address data model, wherein the e-mail address data model is associated with at least two functions to be performed on the e-mail address, and the e-mail address controller is configured to display the at least two functions;
display, by the e-mail address controller at the mobile communication device, on the display an a first interface for selecting from including the at least two functions that can be performed with the e-mail address, the at least two functions including adding the e-mail address to an address book and creating an e-mail message addressed to the e-mail address to be performed on the e-mail address, wherein the at least two functions include a first function executed by a second application and a second function executed by a third application different than the first and second applications;
receive, from the first interface, a selection of the first function executed by the second application;
launch, by the e-mail address controller, the second application;
retrieve, by the message controller using the SMS data model, the e-mail address from the SMS message; and
provide, by the message controller, the retrieved e-mail address to the second application.
9. The mobile communication device of claim 8, wherein the electronic message is an e-mail message.
10. The mobile communication device of claim 8, wherein the electronic message is an SMS message.
11. The mobile communication device of claim 8, wherein the at least two functions comprise an operation involving an application other than a message application.
12. The mobile communication device of claim 8, wherein the at least two functions comprise an operation involving an address book application.
13. The mobile communication device of claim 8, wherein the receiving the selection of the displayed e-mail address comprises receiving a cursor positioning over the e-mail address.
14. The mobile communication device of claim 8, further comprising the processor configured to receive selection of one of the at least two functions.
15. The mobile communication device of claim 14, further comprising the processor configured to launch an application associated with the selected function.
16. The method mobile communication device of claim 8, wherein the first interface comprises a menu list.
17. A method of providing functionality on a mobile device having a display, comprising:
receiving at the mobile device an e-mail message with an e-mail address within a body of the e-mail message;
displaying on the display at least a portion of the e-mail message including the e-mail address;
in response to a selection of the displayed e-mail address, displaying on the display a list of at least two functions that can be performed with the e-mail address, the at least two functions including adding the e-mail address to an address book on the mobile device and creating an e-mail message addressed to the e-mail address; and
receiving a selection of at least one of the at least two functions, and then performing the selected function.
18. A mobile communication device, comprising:
a display;
a transceiver; and
a processor connected with the display and the transceiver, the processor configured for:
receiving with the transceiver an e-mail message having an e-mail address within a body of the e-mail message;
displaying on the display at least a portion of the e-mail message including the e-mail address;
in response to a selection of the displayed e-mail address, displaying on the display a list of at least two functions that can be performed with the e-mail address, the at least two functions including adding the e-mail address to an address book on the mobile device and creating an e-mail message addressed to the e-mail address; and
receiving a selection of at least one of the at least two functions, and then performing the selected function.
19. A non-transitory computer readable medium storing instructions to cause a processor to perform operations comprising:
receiving, at a mobile device, a short message service (SMS) message having a body, with an e-mail address within the body;
displaying at least a portion of the SMS message including the e-mail address, wherein the portion of the SMS message is displayed in a first application;
determining, by a message controller at the mobile device, that the SMS message includes the e-mail address, wherein the message controller is associated with an SMS data model, and the SMS data model includes a retrieving function for retrieving the e-mail address from the SMS message;
after determining that the SMS message includes the e-mail address, determining that a cursor is effected near the displayed e-mail address; and
in response to determining that the cursor is effected near the displayed e-mail address, activating, by the message controller, an e-mail address controller, wherein the e-mail address controller is different than the message controller, the e-mail address controller is associated with an e-mail address data model, wherein the e-mail address data model is associated with at least two functions to be performed on the e-mail address, and the e-mail address controller is configured to display the at least two functions;
displaying, by the e-mail address controller at the mobile device, an interface including the at least two functions to be performed on the e-mail address, wherein the at least two functions include a first function executed by a second application and a second function executed by a third application different than the first and second applications;
receiving, from the interface, a selection of the first function executed by the second application;
launching, by the e-mail address controller, the second application;
retrieving, by the message controller using the SMS data model, the e-mail address from the SMS message; and
providing, by the message controller, the retrieved e-mail address to the second application.
20. The computer readable medium of claim 19, wherein the interface comprises a menu list.
US14/298,755 2000-06-30 2014-06-06 System and method for an extendable mobile communications device user interface Expired - Fee Related USRE47081E1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/298,755 USRE47081E1 (en) 2000-06-30 2014-06-06 System and method for an extendable mobile communications device user interface

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
US21560500P 2000-06-30 2000-06-30
US09/897,207 US6990672B2 (en) 2000-06-30 2001-07-02 System and method for an extendable mobile communications device user interface
US11/237,010 US7805729B2 (en) 2000-06-30 2005-09-28 System and method for an extendable mobile communications device user interface
US12/887,758 US8275844B2 (en) 2000-06-30 2010-09-22 System and method for an extendable mobile communications device user interface
US13/244,793 US8275846B2 (en) 2000-06-30 2011-09-26 System and method for an extendable mobile communications device user interface
US14/298,755 USRE47081E1 (en) 2000-06-30 2014-06-06 System and method for an extendable mobile communications device user interface

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US13/244,793 Reissue US8275846B2 (en) 2000-06-30 2011-09-26 System and method for an extendable mobile communications device user interface

Publications (1)

Publication Number Publication Date
USRE47081E1 true USRE47081E1 (en) 2018-10-09

Family

ID=22803658

Family Applications (5)

Application Number Title Priority Date Filing Date
US09/897,207 Expired - Lifetime US6990672B2 (en) 2000-06-30 2001-07-02 System and method for an extendable mobile communications device user interface
US11/237,010 Active 2025-04-01 US7805729B2 (en) 2000-06-30 2005-09-28 System and method for an extendable mobile communications device user interface
US12/887,758 Expired - Fee Related US8275844B2 (en) 2000-06-30 2010-09-22 System and method for an extendable mobile communications device user interface
US13/244,793 Ceased US8275846B2 (en) 2000-06-30 2011-09-26 System and method for an extendable mobile communications device user interface
US14/298,755 Expired - Fee Related USRE47081E1 (en) 2000-06-30 2014-06-06 System and method for an extendable mobile communications device user interface

Family Applications Before (4)

Application Number Title Priority Date Filing Date
US09/897,207 Expired - Lifetime US6990672B2 (en) 2000-06-30 2001-07-02 System and method for an extendable mobile communications device user interface
US11/237,010 Active 2025-04-01 US7805729B2 (en) 2000-06-30 2005-09-28 System and method for an extendable mobile communications device user interface
US12/887,758 Expired - Fee Related US8275844B2 (en) 2000-06-30 2010-09-22 System and method for an extendable mobile communications device user interface
US13/244,793 Ceased US8275846B2 (en) 2000-06-30 2011-09-26 System and method for an extendable mobile communications device user interface

Country Status (2)

Country Link
US (5) US6990672B2 (en)
CA (1) CA2352024C (en)

Families Citing this family (44)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6990672B2 (en) 2000-06-30 2006-01-24 Research In Motion Limited System and method for an extendable mobile communications device user interface
US20020073156A1 (en) * 2000-12-08 2002-06-13 Xerox Corporation Method and system for mail folder displays
US7774409B2 (en) * 2002-08-27 2010-08-10 International Business Machines Corporation Providing common contact discovery and management to electronic mail users
US20050215238A1 (en) * 2004-03-24 2005-09-29 Macaluso Anthony G Advertising on mobile devices
US7257822B1 (en) * 2004-04-13 2007-08-14 Sun Microsystems Inc Method and system for address book application programming interface
US7218943B2 (en) * 2004-12-13 2007-05-15 Research In Motion Limited Text messaging conversation user interface functionality
US20060136287A1 (en) * 2004-12-22 2006-06-22 Microsoft Corporation Method and apparatus for creating a list for marketing
CN1957577B (en) * 2005-04-18 2012-02-08 捷讯研究有限公司 Method for handling communications over a non-permanent communication link
US20080275764A1 (en) * 2005-04-25 2008-11-06 Wilson Eric S Content management system and method
US20080305781A1 (en) * 2005-04-25 2008-12-11 Wilson Eric S Cognitive scheduler
AU2006238849A1 (en) * 2005-04-25 2006-11-02 Sidebar, Inc. System and method for consumer engagement and revenue optimization
US20100049608A1 (en) * 2005-04-25 2010-02-25 Grossman Stephanie L Third party content management system and method
US20090164310A1 (en) * 2005-04-25 2009-06-25 Grossman Stephanie L Method for providing mobile commerce and revenue optimization
US20070089071A1 (en) * 2005-10-14 2007-04-19 Research In Motion Limited Software mechanism for providing distinct types of time dependent event objects for display in a graphical user interface
EP2104062A3 (en) * 2005-10-14 2010-01-20 Research In Motion Limited Software mechanism for providing distinct types of time dependent event objects for display in a graphical user interface
US8745060B2 (en) 2007-07-25 2014-06-03 Yahoo! Inc. Indexing and searching content behind links presented in a communication
US9584343B2 (en) 2008-01-03 2017-02-28 Yahoo! Inc. Presentation of organized personal and public data using communication mediums
US20090228361A1 (en) * 2008-03-10 2009-09-10 Wilson Eric S Cognitive scheduler for mobile platforms
JP2010033437A (en) * 2008-07-30 2010-02-12 Autonetworks Technologies Ltd Control apparatus, control method, and computer program
US20100088157A1 (en) * 2008-10-06 2010-04-08 Sidebar, Inc. System and method for the throttled delivery of advertisements and content based on a sliding scale of usage
EP2438571A4 (en) 2009-06-02 2014-04-30 Yahoo Inc Self populating address book
US8984074B2 (en) 2009-07-08 2015-03-17 Yahoo! Inc. Sender-based ranking of person profiles and multi-person automatic suggestions
US8990323B2 (en) 2009-07-08 2015-03-24 Yahoo! Inc. Defining a social network model implied by communications data
US7930430B2 (en) 2009-07-08 2011-04-19 Xobni Corporation Systems and methods to provide assistance during address input
US9721228B2 (en) 2009-07-08 2017-08-01 Yahoo! Inc. Locally hosting a social network using social data stored on a user's computer
US9087323B2 (en) 2009-10-14 2015-07-21 Yahoo! Inc. Systems and methods to automatically generate a signature block
US9514466B2 (en) 2009-11-16 2016-12-06 Yahoo! Inc. Collecting and presenting data including links from communications sent to or from a user
US9760866B2 (en) 2009-12-15 2017-09-12 Yahoo Holdings, Inc. Systems and methods to provide server side profile information
US9852218B1 (en) * 2010-01-01 2017-12-26 Joseph Alan Epstein System and method for distributing media via portable storage
US8924956B2 (en) * 2010-02-03 2014-12-30 Yahoo! Inc. Systems and methods to identify users using an automated learning process
US9020938B2 (en) 2010-02-03 2015-04-28 Yahoo! Inc. Providing profile information using servers
US8754848B2 (en) 2010-05-27 2014-06-17 Yahoo! Inc. Presenting information to a user based on the current state of a user device
US8620935B2 (en) 2011-06-24 2013-12-31 Yahoo! Inc. Personalizing an online service based on data collected for a user of a computing device
US8972257B2 (en) 2010-06-02 2015-03-03 Yahoo! Inc. Systems and methods to present voice message information to a user of a computing device
US8751234B2 (en) 2011-04-27 2014-06-10 Blackberry Limited Communication device for determining contextual information
US10078819B2 (en) 2011-06-21 2018-09-18 Oath Inc. Presenting favorite contacts information to a user of a computing device
US9747583B2 (en) 2011-06-30 2017-08-29 Yahoo Holdings, Inc. Presenting entity profile information to a user of a computing device
US10977285B2 (en) 2012-03-28 2021-04-13 Verizon Media Inc. Using observations of a person to determine if data corresponds to the person
US10013672B2 (en) 2012-11-02 2018-07-03 Oath Inc. Address extraction from a communication
US10192200B2 (en) 2012-12-04 2019-01-29 Oath Inc. Classifying a portion of user contact data into local contacts
US10817481B2 (en) 2013-06-18 2020-10-27 Blackberry Limited Managing contact records between service provider accounts of a user
FR3099619A1 (en) * 2019-07-30 2021-02-05 Amadeus Device, system and method for mode-based synchronization of data records
US11941617B2 (en) 2020-12-01 2024-03-26 Capital One Services, Llc Computer-based systems configured to provide pre-staged transactions via lockers and methods of use thereof
US11463434B2 (en) 2021-01-05 2022-10-04 Capital One Services, Llc Computer-based systems involving enhanced one-time passcode (OTP) messaging and methods of use thereof

Citations (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5649222A (en) * 1995-05-08 1997-07-15 Microsoft Corporation Method for background spell checking a word processing document
US5859636A (en) * 1995-12-27 1999-01-12 Intel Corporation Recognition of and operation on text data
US5946629A (en) * 1995-11-28 1999-08-31 Telefonaktiebolaget L M Ericsson Cellular telephone network having short message service interaction with other networks
US5946647A (en) * 1996-02-01 1999-08-31 Apple Computer, Inc. System and method for performing an action on a structure in computer-generated data
US5966652A (en) * 1996-08-29 1999-10-12 Qualcomm Incorporated System and method for the insertion and extraction of telephone numbers from a wireless text message
US6005942A (en) 1997-03-24 1999-12-21 Visa International Service Association System and method for a multi-application smart card which can facilitate a post-issuance download of an application onto the smart card
US6020889A (en) * 1997-11-17 2000-02-01 International Business Machines Corporation System for displaying a computer managed network layout with varying transience display of user selected attributes of a plurality of displayed network objects
US6121968A (en) * 1998-06-17 2000-09-19 Microsoft Corporation Adaptive menus
US6282294B1 (en) 1998-01-07 2001-08-28 Microsoft Corporation System for broadcasting to, and programming, a motor device in a protocol, device, and network independent fashion
US6292833B1 (en) 1998-07-17 2001-09-18 Openwave Systems Inc. Method and apparatus for providing access control to local services of mobile devices
US6421717B1 (en) 1999-09-10 2002-07-16 Avantgo, Inc. System, method, and computer program product for customizing channels, content, and data for mobile devices
US6424360B1 (en) * 1995-09-21 2002-07-23 International Business Machines Corporation Dynamically constructed integration menus
US6467081B2 (en) * 1998-11-13 2002-10-15 Microsoft Corporation Automated help system for reference information
US20020156938A1 (en) 2001-04-20 2002-10-24 Ivan Wong Mobile multimedia java framework application program interface
US6493006B1 (en) * 1996-05-10 2002-12-10 Apple Computer, Inc. Graphical user interface having contextual menus
US6553223B1 (en) 1999-12-30 2003-04-22 Qualcomm Incorporated Virtual device architecture for mobile telephones
US20030097361A1 (en) 1998-12-07 2003-05-22 Dinh Truong T Message center based desktop systems
US6684269B2 (en) 1995-06-22 2004-01-27 Datascape Inc. System and method for enabling transactions between a web server and a smart card, telephone, or personal digital assistant over the internet
US6834372B1 (en) * 2000-02-10 2004-12-21 International Business Machines Corporation Internet web browser with proximity sensitie hyperlink history report
US20050027802A1 (en) * 1999-09-28 2005-02-03 Mark Madsen System and method for managing information and collaborating
US20050044148A1 (en) 2000-06-29 2005-02-24 Microsoft Corporation Method and system for accessing multiple types of electronic content
US6870828B1 (en) * 1997-06-03 2005-03-22 Cisco Technology, Inc. Method and apparatus for iconifying and automatically dialing telephone numbers which appear on a Web page
US20060026603A1 (en) 2000-06-30 2006-02-02 Michael Maguire System and method for an extendable mobile communications device user interface
US7003327B1 (en) * 1999-07-23 2006-02-21 Openwave Systems Inc. Heuristically assisted user interface for a wireless communication device
US7010616B2 (en) * 1996-05-31 2006-03-07 Microsoft Corporation Method for automatically implementing special forms in an e-mail system
US7054464B2 (en) 1992-07-08 2006-05-30 Ncs Pearson, Inc. System and method of distribution of digitized materials and control of scoring for open-ended assessments
US7117445B2 (en) * 2003-06-30 2006-10-03 Danger, Inc. Multi-mode communication apparatus and interface for contacting a user
US7747948B2 (en) * 2001-01-08 2010-06-29 Lg Electronics Inc. Method of storing data in a personal information terminal
US20150160803A1 (en) * 2007-06-26 2015-06-11 Qualcomm Incorporated Technique for enabling multiple actions to be performed on an active data item

Patent Citations (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7054464B2 (en) 1992-07-08 2006-05-30 Ncs Pearson, Inc. System and method of distribution of digitized materials and control of scoring for open-ended assessments
US5649222A (en) * 1995-05-08 1997-07-15 Microsoft Corporation Method for background spell checking a word processing document
US6684269B2 (en) 1995-06-22 2004-01-27 Datascape Inc. System and method for enabling transactions between a web server and a smart card, telephone, or personal digital assistant over the internet
US6424360B1 (en) * 1995-09-21 2002-07-23 International Business Machines Corporation Dynamically constructed integration menus
US5946629A (en) * 1995-11-28 1999-08-31 Telefonaktiebolaget L M Ericsson Cellular telephone network having short message service interaction with other networks
US5859636A (en) * 1995-12-27 1999-01-12 Intel Corporation Recognition of and operation on text data
US5946647A (en) * 1996-02-01 1999-08-31 Apple Computer, Inc. System and method for performing an action on a structure in computer-generated data
US6493006B1 (en) * 1996-05-10 2002-12-10 Apple Computer, Inc. Graphical user interface having contextual menus
US7010616B2 (en) * 1996-05-31 2006-03-07 Microsoft Corporation Method for automatically implementing special forms in an e-mail system
US5966652A (en) * 1996-08-29 1999-10-12 Qualcomm Incorporated System and method for the insertion and extraction of telephone numbers from a wireless text message
US6005942A (en) 1997-03-24 1999-12-21 Visa International Service Association System and method for a multi-application smart card which can facilitate a post-issuance download of an application onto the smart card
US6870828B1 (en) * 1997-06-03 2005-03-22 Cisco Technology, Inc. Method and apparatus for iconifying and automatically dialing telephone numbers which appear on a Web page
US6020889A (en) * 1997-11-17 2000-02-01 International Business Machines Corporation System for displaying a computer managed network layout with varying transience display of user selected attributes of a plurality of displayed network objects
US6282294B1 (en) 1998-01-07 2001-08-28 Microsoft Corporation System for broadcasting to, and programming, a motor device in a protocol, device, and network independent fashion
US20020046343A1 (en) 1998-01-07 2002-04-18 Vinay Deo System for broadcasting to, and programming, a mobile device in a protocol
US6121968A (en) * 1998-06-17 2000-09-19 Microsoft Corporation Adaptive menus
US6292833B1 (en) 1998-07-17 2001-09-18 Openwave Systems Inc. Method and apparatus for providing access control to local services of mobile devices
US6467081B2 (en) * 1998-11-13 2002-10-15 Microsoft Corporation Automated help system for reference information
US20030097361A1 (en) 1998-12-07 2003-05-22 Dinh Truong T Message center based desktop systems
US7003327B1 (en) * 1999-07-23 2006-02-21 Openwave Systems Inc. Heuristically assisted user interface for a wireless communication device
US6421717B1 (en) 1999-09-10 2002-07-16 Avantgo, Inc. System, method, and computer program product for customizing channels, content, and data for mobile devices
US20050027802A1 (en) * 1999-09-28 2005-02-03 Mark Madsen System and method for managing information and collaborating
US6553223B1 (en) 1999-12-30 2003-04-22 Qualcomm Incorporated Virtual device architecture for mobile telephones
US6834372B1 (en) * 2000-02-10 2004-12-21 International Business Machines Corporation Internet web browser with proximity sensitie hyperlink history report
US20050044148A1 (en) 2000-06-29 2005-02-24 Microsoft Corporation Method and system for accessing multiple types of electronic content
US20060026603A1 (en) 2000-06-30 2006-02-02 Michael Maguire System and method for an extendable mobile communications device user interface
US7747948B2 (en) * 2001-01-08 2010-06-29 Lg Electronics Inc. Method of storing data in a personal information terminal
US20020156938A1 (en) 2001-04-20 2002-10-24 Ivan Wong Mobile multimedia java framework application program interface
US7117445B2 (en) * 2003-06-30 2006-10-03 Danger, Inc. Multi-mode communication apparatus and interface for contacting a user
US20150160803A1 (en) * 2007-06-26 2015-06-11 Qualcomm Incorporated Technique for enabling multiple actions to be performed on an active data item

Non-Patent Citations (12)

* Cited by examiner, † Cited by third party
Title
Canadian Office Action for CA Application Serial No. 2,352,024 mailed Apr. 27, 2005; 2 pages.
Canadian Office Action for CA Application Serial No. 2,352,024 mailed Feb. 2, 2004; 2 pages.
Canadian Office Action for CA Application Serial No. 2,352,024 mailed Mar. 2, 2007; 2 pages.
Ernest Ackerman & Karen Hartman, "Email Basics," Nov. 13, 1998; retrieved on Nov. 11, 2014 from http://webliminal.com/search/bemail.htm. *
Jonathan O'Donnell, "Business Communications, Communications on the Internet," Jun. 3, 2000; retrieved on Jul. 28, 2014 from http://www.jod.id.au/latrobe.html. *
Michael Antoniak, "Buyer's Guide: Handheld Computers and PDAs," Mar. 1998; retrieved on Nov. 7, 2014 from http://realtormag.realtor.org. *
U.S. Appl. No. 09/897,207; Non-Final Office Action; Date Filed: Jul. 2, 2001; Date Mailed: Mar. 18, 2005; pp. 1-12.
U.S. Appl. No. 09/897,207; Notice of Allowance; Date Filed: Jul. 2, 2001; Date Mailed: Jul. 6, 2005; pp. 1-4.
U.S. Appl. No. 11/237,010; Non-Final Office Action; Date Filed: Sep. 28, 2005; Mail Date: Oct. 19, 2009; pp. 1-8.
U.S. Appl. No. 11/237,010; Notice of Allowance; Date Filed: Sep. 28, 2005; Mail Date: May 26, 2010; pp. 1-6.
US Notice of Allowance for U.S. Appl. No. 12/887,758 mailed Feb. 21, 2012; 7 pages.
US Office Action for U.S. Appl. No. 12/887,758 mailed Nov. 9, 2011; 9 pages.

Also Published As

Publication number Publication date
US20120017158A1 (en) 2012-01-19
US8275844B2 (en) 2012-09-25
US7805729B2 (en) 2010-09-28
US20060026603A1 (en) 2006-02-02
US20020107991A1 (en) 2002-08-08
CA2352024A1 (en) 2001-12-30
CA2352024C (en) 2008-04-01
US20110010639A1 (en) 2011-01-13
US8275846B2 (en) 2012-09-25
US6990672B2 (en) 2006-01-24

Similar Documents

Publication Publication Date Title
USRE47081E1 (en) System and method for an extendable mobile communications device user interface
CA2535431C (en) System and method for integrating an address book with an instant messaging application in a mobile station
US8739071B2 (en) System and method for message display and management
US9332079B2 (en) Generic activation and registration framework for wireless devices
US8504923B2 (en) System and method of skinning themes
CN103294335A (en) Apparatus and method for creating a shortcut menu
US7590430B1 (en) Architecture and applications to support device-driven firmware upgrades and configurable menus
CN100419684C (en) Method for setting up short-cut of programe module in software and starting method therefor
EP1879405A1 (en) Method for appending a signature to a size limited text message
US20060277535A1 (en) Downloading software applications
CN102547630B (en) Mobile terminal service multimedia displaying method, terminal and system
CN101169715A (en) Control adding method
EP1569427A1 (en) System and method for the management and display of heterogeneous messages
CN117376120A (en) Channel-configurable message pushing method, system, device and storage medium

Legal Events

Date Code Title Description
AS Assignment

Owner name: BLACKBERRY LIMITED, ONTARIO

Free format text: CHANGE OF NAME;ASSIGNOR:RESEARCH IN MOTION LIMITED;REEL/FRAME:034827/0502

Effective date: 20130709

AS Assignment

Owner name: RESEARCH IN MOTION LIMITED, CANADA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:MAGUIRE, MICHAEL;PATHIYAL, KRISHNA K.;REEL/FRAME:041024/0552

Effective date: 20011022

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

AS Assignment

Owner name: MALIKIE INNOVATIONS LIMITED, IRELAND

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BLACKBERRY LIMITED;REEL/FRAME:064104/0103

Effective date: 20230511

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY