EP1256048A2 - System und verfahren zum betreiben einer benutzerschnittstelle mit einer elektronischen lesevorrichtung - Google Patents

System und verfahren zum betreiben einer benutzerschnittstelle mit einer elektronischen lesevorrichtung

Info

Publication number
EP1256048A2
EP1256048A2 EP01913802A EP01913802A EP1256048A2 EP 1256048 A2 EP1256048 A2 EP 1256048A2 EP 01913802 A EP01913802 A EP 01913802A EP 01913802 A EP01913802 A EP 01913802A EP 1256048 A2 EP1256048 A2 EP 1256048A2
Authority
EP
European Patent Office
Prior art keywords
address pattern
application
reading device
electronic reading
electronic pen
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.)
Withdrawn
Application number
EP01913802A
Other languages
English (en)
French (fr)
Inventor
Magnus Hollström
Patrik Olsson
Magnus Tillgren
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.)
Telefonaktiebolaget LM Ericsson AB
Original Assignee
Telefonaktiebolaget LM Ericsson AB
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
Priority claimed from US09/703,506 external-priority patent/US6611259B1/en
Application filed by Telefonaktiebolaget LM Ericsson AB filed Critical Telefonaktiebolaget LM Ericsson AB
Publication of EP1256048A2 publication Critical patent/EP1256048A2/de
Withdrawn legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/016Input arrangements with force or tactile feedback as computer generated output to the user
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B41PRINTING; LINING MACHINES; TYPEWRITERS; STAMPS
    • B41JTYPEWRITERS; SELECTIVE PRINTING MECHANISMS, i.e. MECHANISMS PRINTING OTHERWISE THAN FROM A FORME; CORRECTION OF TYPOGRAPHICAL ERRORS
    • B41J2/00Typewriters or selective printing mechanisms characterised by the printing or marking process for which they are designed
    • B41J2/315Typewriters or selective printing mechanisms characterised by the printing or marking process for which they are designed characterised by selective application of heat to a heat sensitive printing or impression-transfer material
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B41PRINTING; LINING MACHINES; TYPEWRITERS; STAMPS
    • B41JTYPEWRITERS; SELECTIVE PRINTING MECHANISMS, i.e. MECHANISMS PRINTING OTHERWISE THAN FROM A FORME; CORRECTION OF TYPOGRAPHICAL ERRORS
    • B41J29/00Details of, or accessories for, typewriters or selective printing mechanisms not otherwise provided for
    • B41J29/38Drives, motors, controls or automatic cut-off devices for the entire printing mechanism
    • B41J29/393Devices for controlling or analysing the entire machine ; Controlling or analysing mechanical parameters involving printing of test patterns
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B41PRINTING; LINING MACHINES; TYPEWRITERS; STAMPS
    • B41JTYPEWRITERS; SELECTIVE PRINTING MECHANISMS, i.e. MECHANISMS PRINTING OTHERWISE THAN FROM A FORME; CORRECTION OF TYPOGRAPHICAL ERRORS
    • B41J3/00Typewriters or selective printing or marking mechanisms characterised by the purpose for which they are constructed
    • B41J3/36Typewriters or selective printing or marking mechanisms characterised by the purpose for which they are constructed for portability, i.e. hand-held printers or laptop printers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/955Retrieval from the web using information identifiers, e.g. uniform resource locators [URL]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/0304Detection arrangements using opto-electronic means
    • G06F3/0317Detection arrangements using opto-electronic means in co-operation with a patterned surface, e.g. absolute position or relative movement detection for an optical mouse or pen positioned with respect to a coded surface
    • G06F3/0321Detection arrangements using opto-electronic means in co-operation with a patterned surface, e.g. absolute position or relative movement detection for an optical mouse or pen positioned with respect to a coded surface by optically sensing the absolute position with respect to a regularly patterned surface forming a passive digitiser, e.g. pen optically detecting position indicative tags printed on a paper sheet
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/033Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
    • G06F3/0354Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor with detection of 2D relative movements between the device, or an operating part thereof, and a plane or surface, e.g. 2D mice, trackballs, pens or pucks
    • G06F3/03545Pens or stylus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/033Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
    • G06F3/038Control and interface arrangements therefor, e.g. drivers or device-embedded control circuitry
    • 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/46Multiprogramming arrangements
    • G06F9/465Distributed object oriented systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00281Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a telecommunication apparatus, e.g. a switched network of teleprinters for the distribution of text-based information, a selective call terminal
    • H04N1/00307Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a telecommunication apparatus, e.g. a switched network of teleprinters for the distribution of text-based information, a selective call terminal with a mobile telephone apparatus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/04Scanning arrangements, i.e. arrangements for the displacement of active reading or reproducing elements relative to the original or reproducing medium, or vice versa
    • H04N1/10Scanning arrangements, i.e. arrangements for the displacement of active reading or reproducing elements relative to the original or reproducing medium, or vice versa using flat picture-bearing surfaces
    • H04N1/107Scanning arrangements, i.e. arrangements for the displacement of active reading or reproducing elements relative to the original or reproducing medium, or vice versa using flat picture-bearing surfaces with manual scanning
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W92/00Interfaces specially adapted for wireless communication networks
    • H04W92/04Interfaces between hierarchically different network devices
    • H04W92/08Interfaces between hierarchically different network devices between user and terminal device

Definitions

  • the present invention relates in general to the communications field, and in particular to an interaction of an electronic reading device with an address pattern. Description of Related Art
  • a keyboard can be used to accept typed input and other types of commands
  • a mouse or a track-ball can be used to provide relative motion input as well as various types of point-and-click selections
  • a keypad can be used to provide input of numerical data and functional commands
  • navigational keys can be used for scrolling lists or otherwise repositioning a cursor
  • various types of touchpads or touchscreens can be used to provide absolute positional coordinate inputs.
  • Each type of mechanism for accepting input and for supporting user interaction has benefits and disadvantages in terms of size, convenience, flexibility, responsiveness, and easy of use.
  • the present invention comprises a method and system for operating an electronic reading device based user interface.
  • the electronic reading device detects portions of an address pattern for use in identifying successive positions of the electronic reading device relative to the address pattern. Initially, data identifying a detected portion of the address pattern is sent to a client device.
  • the client device uses the received data to locate an address of an application server that contains an application description for an area of the address pattern that includes the detected portion.
  • a request for the application description is then sent to the application server, which responds by retrieving the application description and forwarding it to the client device.
  • the client device uses the application description for processing subsequently detected successive positions on the address pattern.
  • the electronic reading device includes a sensor for detecting portions of the address pattern and a position buffer for storing data identifying the detected portions of the address pattern.
  • a memory stores a grid description of a current address pattern area.
  • the grid description is included in the application description and is forwarded to the electronic reading device when the application description is received by the client device.
  • a processor in the electronic reading device uses the grid description, determines a position for each successive portion of the address pattern stored in the position buffer. The positions are then used to generate strokes, which are further processed to initiate actions corresponding to the generated strokes. These actions can be sent to the client device for further processing in accordance with the current application description.
  • the system also includes a name server for use in identifying an address of an application server associated with a detected position, a base translator for performing generic translations of information entered with the electronic reading device, and a control node for processing detected positions in a standardized way and/or for use in real-time control applications.
  • the electronic reading device can be used in connection with a separate electronic device for configuring the electronic reading device or for interacting with an application.
  • configuration data for the electronic reading device can be sent to the separate electronic device, and an MMI for the separate electronic device can be used to select desired options in the configuration data.
  • application data can be sent to the separate electronic device where the data is displayed on a display screen. The user can then make a selection relating to the application either using an MMI for the separate electronic device or by using the electronic reading device on an appropriate field on the address pattern.
  • an electronic reading device includes a sensor for detecting portions of an address pattern on a formatted surface. Areas of the address pattern are grouped together in a selected manner, such that each grouping comprises a specific area of the address pattern.
  • a processor identifies positions of the electronic reading device relative to the address pattern based on the detected portions of the address pattern. Furthermore, the processor determines whether two or more identified positions are associated with the same grouping based on the detected portions of the address pattern.
  • the processor identifies each position based on a first attribute of a specific detected portion of the address pattern and determines whether two or more identified positions are associated with the same grouping based on a second attribute of the specific detected portion of the address pattern.
  • the first attribute can comprise a first subset of bits from a multiple bit code that corresponds to the specific detected portion of the address pattern
  • the second attribute can comprise a second subset of bits from the multiple bit code.
  • an address pattern is generated such that each position on the address pattern is associated with a unique portion of the address pattern and each unique portion has a corresponding unique address. Areas of the address pattern are allocated for use in connection with applications. This allocation is based on a first specific portion of the unique address.
  • a particular one of the allocated areas is assigned an application class, and a region of the address pattern is selected from the particular allocated area such that a second specific portion of the unique address for the selected region corresponds to the assigned application class.
  • groupings on an address pattern _ re identified by detecting a first portion of the address p ⁇ ttern, wherein the address pattern is segmented into sectors each of which belongs to one of a plurality of classes A first position on the address pattern is identified based on the detected first portion of the address pattern, and a class for a sector that contains the first position is determined based on the detected first portion of the address pattern.
  • FIGURE 1 is a block diagram of a system in which an electronic pen can be used as an input device
  • FIGURE 2 is a schematic diagram of a system for supporting use of the electronic pen described in connection with FIGURE
  • FIGURE 3 is an illustration of the protocol stacks that can be used in the case of local communications between an electronic pen and an electronic pen client;
  • FIGURE 4 is an illustration of protocol stacks that can be used when an electronic pen and an electronic pen client communicate with one another via an Internet connection;
  • FIGURE 5 is an illustration of a protocol stack for communications between an electronic pen client and each of the supporting entities when the electronic pen client is not located within a server on the Internet
  • FIGURE 6 is an illustration of protocol stacks that are used for communications between an electronic pen client and each of the supporting entities when the electronic pen client is located on the Internet
  • FIGURE 7 is a block diagram of the electronic pen logic that handles positions, strokes, actions, and grid descriptions
  • FIGURE 8 is a block diagram of a state machine for the electronic pen control block shown in FIGURE 7;
  • FIGURE 9 is a block diagram of a state machine for an electronic pen client;
  • FIGURES 10A-10C are a message flow and signaling diagram illustrating the operation of the electronic pen system shown and discussed in connection with FIGURE 2;
  • FIGURE 11 is a message flow and signaling diagram for configuring an electronic pen using a wireless application protocol (WAP) browser in a mobile phone;
  • WAP wireless application protocol
  • FIGURE 12 illustrates a message flow and signaling diagram for configuring an electronic pen using an application program interface (API) for a mobile phone MMI;
  • API application program interface
  • FIGURE 13 is a message flow and signaling diagram for providing an application interaction using WAP communications between a mobile phone and an application server.
  • FIGURE 14 is a message flow and signaling diagram for providing application interaction using WAP communications wherein the electronic pen acts as a proxy towards the mobile phone;
  • FIGURE 15 is a message flow and signaling diagram for supporting application interaction via AT commands between an electronic pen, a mobile phone, and an application server;
  • FIGURE 16 is a message flow signaling diagram for providing application interaction using AT commands to create dynamic menus; and FIGURE 17 is a schematic diagram of an area of the address space in accordance with the present invention.
  • the present invention relates to a system in which an electronic reading device, such as an electronic pen, an electronic mouse, or a hand scanner, works in cooperation with an address pattern (e.g., a specially formatted paper) to provide for a detection of a location of the electronic reading device over the address pattern.
  • an address pattern e.g., a specially formatted paper
  • a pattern of dots can be defined such that, by examining a very small portion of the pattern, a precise location in the overall pattern can be determined.
  • the pen can detect its position (e.g. , using a built in camera) by detecting a 3 mm by 3 mm portion of the pattern. By taking approximately 100 pictures per second, the pen is capable of determining its exact position to within 0.1 mm or less.
  • This system can be used to provide user input, to facilitate user interaction, or to store handwritten notes or drawings.
  • by associating portions of the overall pattern with certain applications such a system can be used to interact with wide variety of applications.
  • the electronic pen 10 includes an ink cartridge and is capable of writing in a typical fashion.
  • the electronic pen 10 includes some type of sensor (e.g., a built-in camera) that is used for detecting an address pattern on a specially formatted piece of paper 12.
  • the paper 12 is formatted with a small portion of a large address pattern such that when the electronic pen 10 is used to write on or otherwise make marks on the paper 12, the writings or markings can be electronically detected and stored.
  • the paper 12 might constitute a form that can be used for sending an email.
  • the paper 12 might include a space for writing in the email address of an intended recipient, a space for writing a subject of the email, and a space for writing the body of the email.
  • the position and movement of the electronic pen 10 on the paper 12 can be determined by repeatedly detecting the current x, y coordinates of the pen 10 (e.g., at rate of 100 frames per second) .
  • the markings can then be converted into ASCII text using an appropriate handwriting recognition program.
  • the email can be sent, for example, by checking a send box at a predetermined location on the paper 12.
  • the coordinate information collected by the pen 10 is sent by a short range radio transmitter in the electronic pen 10 to a nearby mobile station 14 using ⁇ ; ⁇ ⁇ hort range radio interface 16 such as a local wireless radio link (e.g., a local wireless radio link supported by Ericsson's BluetoothTM wireless communications technology) .
  • a local wireless radio link e.g., a local wireless radio link supported by Ericsson's BluetoothTM wireless communications technology
  • the coordinate information could also be sent to, for instance, a desktop or portable computer, a personal digital assistant (PDA), a television, or a Bluetooth terminal.
  • PDA personal digital assistant
  • GSM Global System for Mobile Communication
  • wired transmission media such as a cable
  • FIGURE 2 there is illustrated a schematic diagram of a system 2 for supporting use of the electronic pen 10 described in connection with FIGURE 1.
  • the system 2 is described primarily in connection with an electronic pen 10. It will be understood, however, that the invention and the underlying system 2 can instead use any type of electronic reading device, such as an electronic pen, an electronic mouse, or a hand scanner.
  • the system 2 includes six different entities, including the electronic pen 10, electronic pen client 22, a control node 24, a name server 26, a base translator 28, and an application server 30.
  • these various devices are described and depicted separately, it is also possible to combine two or more of the entities into the same device (e.g., the electronic pen 10 and electronic pen client 22 can be contained in the same device) .
  • the electronic pen 10 is responsible for detecting positions on the address pattern, producing actions, and sending information to the electronic pen client 22. In addition to being able to leave pen markings, some electronic pens can also have the ability to produce other types of output, such as sound, vibration, or flashing lights.
  • the electronic pen 10 includes a memory for storing a current grid, which comprises information relating to an area of the address pattern that is near the most recently detected position of the electronic pen 10. When the electronic pen 10 is loaded with the current grid, it knows what actions to take based on the positions that are read from the address pattern. When the electronic pen 10 is first turned on or when it moves to an area outside of the current grid, the electronic pen 10 must first request a new grid description before it can continue processing information. In such a situation, the electronic pen 10 requests a new grid description from the electronic pen client 22.
  • the electronic pen client 22 can be located in the electronic pen 10, in a PDA, in a mobile station 14, in a desktop or portable computer, in the electronic pen 10 itself, in a server somewhere on the Internet, or in another device.
  • the electronic pen client 22 comprises a processor that serves as the center of communications in the overall system 2.
  • the electronic pen client 22 can comprise a wireless application protocol (WAP) client or web client that is modified to support pattern-based user interfaces.
  • WAP wireless application protocol
  • the electronic pen client 22 receives new grid requests and action requests from the electronic pen 10 and responds to these requests by contacting an appropriate entity within the overall system 2 to properly respond to the request from the electronic pen 10.
  • the electronic pen client 22 can store the application and/or any corresponding data received from the electronic pen 10 to facilitate processing and use of the application.
  • the client functionality could be downloaded dynamically into a mobile phone, electronic reading device, PC, or other electronic device each time an application is accessed or when an application is first used.
  • the downloaded client functionality could be in the form of, for example, a Java applet, a Jini application, or some other similar format.
  • the name server 26 is used for translating a detected position on the address pattern into a Uniform Resource Location (URL) associated with that position. Different portions of the address pattern are assigned to different applications.
  • URL Uniform Resource Location
  • the electronic pen 10 nor the electronic pen client 22, however, is aware of all of the different applications and the particular areas assigned to each application. Thus, when the electronic pen 10 detects a new or unknown position, it forwards the position information to the electronic pen client 22, which in turn sends the information to the name server 26. The name server 26 then identifies an application associated with the received position and retrieves a URL where a description of the particular application can be found. The retrieved URL can then be used by the electronic pen client 22 to retrieve the application description.
  • the name server 26 can comprise a global name server that keeps track of a location, in the form of URLs to local name servers, where more information can be found about different addresses in the pattern.
  • each local name server can use other local name servers to obtain the necessary information, i.e. , to convert a position into a URL where an application description can be found.
  • the local electronic pen client should know all the paper addresses that are within a specific application or applications.
  • the base translator 28 can be used to support the services.
  • the base translator 28 might contain handwriting recognition software for converting pen actions into text or for converting pen actions into a predefined set of symbols.
  • the electronic pen client 22 can send a request to the base translator 28 along with the necessary data, and the base translator 28 can perform the requested service.
  • Another entity in the system 2 is a control node 24.
  • the control node 24 is used for responding to actions in a standardized way.
  • the control node 24 can be used to respond to certain generic functions, such as "cancel" or "submit” functions, in a consistent manner without regard to the particular application that is currently active.
  • control node 24 is used for creating streaming-like applications. For instance, some applications might require that the positions on the address pattern that are detected by the electronic pen 10 be immediately sent, upon detection, to the electronic pen client 22 for use by the application (i.e., the electronic pen 10 does not wait to transmit the position data until a complete stroke is detected or until a "send" field is touched) .
  • One example is an application that is used to control an industrial robot in a warehouse.
  • the application description that is loaded onto the electronic pen server 22 can include instructions that all positions be streamed to a control node 24.
  • the control node 24 can receive the positions in real time and can control the robot without waiting for the form (i.e., the current grid) to be completed.
  • the control node 24 can perform a real-time translation from detected positions to a responsive action, such as moving an object (e.g., a robot, a valve, etc.) or controlling a process.
  • the application server 30 is a regular web or wireless application protocol (WAP) server that supports an application associated with a particular area of the address pattern.
  • the application server 30 can be located in the electronic pen 10, in a mobile station 14, in a desktop or portable computer, on a network server, or in another device.
  • the application server 30 stores an application description and provides the application description to the electronic pen client 22 upon request.
  • the application server 30 receives input data from the electronic pen 10 via the electronic pen client 22.
  • the application description might define a number of data enzierry areas on a form.
  • FIGURES 3 through 6 there are illustrated various examples of protocol stacks that can be used for communicating between the entities shown in FIGURE 2. Generally, however, such protocols apply however, only if the two communicating entities are implemented in different devices. If two or more entities are combined into one device, a proprietary protocol can be used to communicate between the entities.
  • FIGURE 3 illustrates the protocol stacks that can be used in the case of local communications (e.g., using Bluetooth) between the electronic pen 10 and the electronic pen client 22.
  • FIGURE 4 illustrates a protocol stack for communicating between the electronic pen client and each of the supporting entities, such as the name server 26, the control node 24, the base translator 28, and the application server 30, when the electronic pen client 22 is not contained within a server on the Internet (e.g., such as when the electronic pen client 22 is located in a mobile phone 14) .
  • FIGURE 6 depicts the protocol stacks that are used when the electronic pen client 22 is located on the Internet.
  • the electronic pen 10 detects a position on the address pattern that is not within its currently loaded grid or when the electronic pen 10 has no currently loaded grid, the electronic pen 10 initiates a new grid procedure.
  • the new grid procedure involves sending a new grid request ob ect to the electronic pen client 22.
  • the new grid request object contains the newly detected position, a description of the actions that the electronic pen 10 can natively support, and a description of the output signals that the electronic pen 10 supports.
  • the reply to a new grid request object is a grid description, which can be provided by the electronic pen client 22 from its own internal memory or from the information provided by an application server 30.
  • the electronic pen client 22 extracts the grid description fron an application description received from the application server 30.
  • the grid description should only contain action-fleld-types that the electronic pen 10 has indicated that it natively supports, which means that the electronic pen client 22 in some cases should convert the extracted grid description into a format that the electronic pen 10 can understand.
  • the electronic pen client 22 sends an empty grid description to the electronic pen 10, thereby causing the electronic pen 10 to unload its current grid. This can occur, for example, when a particular application is complete or when a new grid description request received from the electronic pen 10 cannot be fulfilled, such as when the position received from the electronic pen 10 is not registered in the name server 26.
  • Another similar message is the empty grid description with a grid exception.
  • the electronic pen client 22 uses the detected position specified in the request to ask the name server 26 for a URL where the application description can be found. If no URL is returned, the electronic pen client 22 can send an empty grid description with a grid exception to the electronic pen 10.
  • the grid exception comprises a rectangle or other shape indicating the area around the detected position where no registered applications can be found. Preferably, the indicated area is as large as possible so that the electronic pen 10 and/or electronic pen client 22 know the extent of the surrounding area that is unassigned and do not have to repeatedly send requests to the name server 26.
  • the empty grid description with a grid exception causes the electronic pen 10 to unload its current grid and also informs the electronic pen 10 of an area surrounding the detected position that can essentially be ignored because its is not associated with any application.
  • the procedure that is used when the electronic pen 10 detects a new position is a find application description location procedure. This procedure is used by the electronic pen client 22 to translate a detected position received from the electronic pen 10 into a URL where a description of an application corresponding to that position can be found. The procedure involves sending a request from the electronic pen client 22 to the name server 26 containing identification of the detected position.
  • the name server 26 responds by sending a reply to the electronic pen client 22 containing a URL where an application description can be found or, if the detected position is not registered in the name server 26, containing an indication that no associated application is known to exist
  • the electronic pen client 22 can initiate a get application description procedure, which allows the electronic pen client 22 to retrieve the application description from the application server 30.
  • the electronic pen client 22 sends an application description request containing a unique ID for the requesting electronic pen 10 and/or electronic pen client 22 to the application server 30 located at the URL address provided by the name server 26.
  • the application server 30 provides an application description object to the electronic pen client 22, which loads the application onto the electronic pen client 22.
  • the application description object is similar to an HTML form with some additions and modifications.
  • the application description object can be sent from the application server 30 to the electronic pen client 22 in response to a submitted form (i.e., a submission of one completed form might automatically result in a new form being loaded onto the electronic pen client 22) .
  • a related procedure is the application submit procedure, which is used by the electronic pen client 22 when the user of the electronic pen 10 selects a "submit" field in a form.
  • the electronic pen client 22 will submit the form content in accordance with instructions received in the application description.
  • the electronic pen client 22 will submit the form content, in the same way as a regular web browser, to a URL specified in a lorm tag of the application description.
  • an action procedure is initiated by the electronic pen 10 to send an action request object to the electronic pen client 22. If the electronic pen client 22 cannot translate the action into a field value itself, the electronic pen client 22 further forwards the request to a base translator 28 for translating the action into a field value.
  • an action reply object is sent from the electronic pen client 22 to the electronic pen 10.
  • the action reply object contains output information that indicates to the electronic pen 10 which outputs signals to use. The output information, however, cannot be of type that the electronic pen 10 has previously indicated that it does not support.
  • the action reply object might contain a new grid description. In such a case the electronic pen 10 will unload its current grid description and load the new grid description. Similarly, if the action reply object contains an empty grid description, the electronic pen 10 will simply unload its current grid description.
  • the action request object is also sometimes used to specify actions that should be processed by the control node 24.
  • the electronic pen client 22 initiates a control procedure by forwarding the received action to the appropriate control node 24.
  • the control node 24 sends an action reply object to the electronic pen client 22
  • Each electronic pen 10 has a unique pen ID, which is sent to the application server 30 when an application description is requested.
  • the electronic pen ID allows the application to identify the particular user that is using the application and to distinguish between multiple concurrent users of the same application, such as when different electronic pens 10 are being used in connection with separate sheets of paper that each contain the same portion of the address pattern.
  • the electronic pen 10 includes a control block 32 for controlling the operation of the electronic pen 10.
  • a grid description block 34 represents a memory location that stores a current grid description. At any given time, the electronic pen 10 can be in either of two modes. In a first mode, a grid description is loaded, while in a second mode, the grid description block 34 is not loaded with a current grid description.
  • the electronic pen 10 As the electronic pen 10 moves across an address pattern, the electronic pen 10 periodically (e.g., every 1/100 of a second) detects a position by detecting all of the dots within, for example, a 3mm by 3mm area. Each detected position is forwarded (as indicated at 36) to a position first in first out
  • FIFO FIFO block 38
  • the clocking of the position FIFO block 38 is controlled by the control block 32 (as indicated at 40) .
  • the detected position is fed from the position FIFO block 38 (as indicated at 42) to an in grid detector 44.
  • the in grid detector 44 retrieves data from the grid description block 34 (as indicated at 46) and determines whether the received position is within the loaded grid description. If not, the in grid detector 44 notifies the control block 32, which in turn initiates a request for a new grid.
  • the position is then sent (as indicated at 50) from the in grid detector 44 to a stroke engine 52.
  • the stroke engine 52 converts the received positions into strokes, which are then sent (as indicated at 54) to an action engine 56.
  • a complete stroke is created when the electronic pen 10 is lifted from the paper or when it moves outside of the grid field where the stroke began.
  • the action engine 56 converts the received stroke into an action that can be sent to the electronic pen client 22.
  • the action engine knows which type of action to produce for a specific grid field.
  • FIGURE 8 there is illustrated a block diagram of a state machine for the control block 32 shown in FIGURE 7.
  • events are indicated in capital letters, while tasks associated with the event are depicted in brackets.
  • the process starts at step 60 with a start up event 62, which causes the position FIFO block 38 to begin receiving detected positions.
  • the electronic pen 10 is in a no grid loaded state 64, which means that the electronic pen 10 does not have a grid loaded in the grid description block 34.
  • the control block 32 generates an outside grid indication 66, thereby causing the electronic pen 10 to send the request for a new grid description to the electronic pen client 22 (i.e. , in accordance with the new grid procedure) and to stop the FIFO buffer 38.
  • the electronic pen 10 enters a waiting for grid state 68.
  • the control block 32 moves to a grid loaded state 72, at which time the new grid is loaded into the grid description block 34 and the position FIFO block 38 resumes operation.
  • the control block 32 moves to a grid loaded state 72, at which time the new grid is loaded into the grid description block 34 and the position FIFO block 38 resumes operation.
  • no grid is received (as indicated at 74) , at least a portion of the positions stored in the FIFO buffer 38 are erased. Which part of the FIFO buffer to erase is determined by the grid exception area, if any, in the received empty grid description. Accordingly, all positions stored in the FIFO buffer 38 that are within the grid exception area should be erased. If no grid exception is received, the stroke associated with the position is erased.
  • the FIFO block 38 resumes operation and the control block 32 moves into the no grid loaded state 64.
  • the control block 32 is in the grid loaded state 72, a current grid is loaded in the grid description block 34.
  • the position FIFO block 38 continues to receive detected positions and passes them on to the stroke engine 52 and action engine 56. Actions produced by the action engine 56 are sent (as indicated at 58) to the electronic pen client 22 (i.e., in accordance with the action procedure described above) .
  • an outside grid indication 74 may be received by the control block 32 from the in grid detector 44. The outside grid event 74 causes the FIFO block 38 to stop generating new positions.
  • the electronic pen 10 enters a flushing stroke and action state 76 wherein the strokes that are currently in the stroke engine 52 and the actions that are currently in the action engine 56 are flushed to the electronic pen client 22.
  • the electronic pen 10 sends a request for a new grid to the electronic pen client 22 and unloads the current grid.
  • the control block 32 then moves back into the waiting for grid state 68.
  • the electronic pen 10 may be capable of supporting various different types of output, including audio, such as warning tones; visual, such as a flashing light; tactile, such as vibration; and/or ink.
  • audio such as warning tones
  • visual such as a flashing light
  • tactile such as vibration
  • ink it might be desirable to allow the user of the electronic pen 10 to turn off the ink of the pen 10, such as when the electronic pen is being used on a portion of the address pattern that is ublic or shared or when the user wants to be able to reuse the current sheet of paper.
  • the electronic pen client 22 will now be described in greater detail.
  • the electronic pen client 22 is analogous to a regular web browser. It is responsible for loading applications from application servers 30 and for handling input form the electronic pen 10.
  • the electronic pen client 22 is located in a separate device from the electronic pen 10 itself. This is because it is desirable to minimize the size and power supply requirements of the electronic pen 10, hich will likely be adversely affected by the processing resc urces and memory necessary to support the functions of the electronic pen client 22.
  • FIGURE 9 there is illustrated a block diagram of a state machine for the electronic pen client 22. Initially, the electronic pen client 22 is in a no application loaded state 80.
  • the electronic pen client 22 recognizes only one signal when in this state 80, namely a new grid request from the electronic pen 10. Such a request causes a load grid indication event 82.
  • the electronic pen client 22 responds by sending a request to the name server 26 to translate a position contained within the new grid request into a URL where the application description can be found (i.e. , in accordance with the find application location procedure) .
  • the electronic pen client 22 enters a waiting for application description URL state 84. If no URL for the application description can be found (as indicated at 86) , the electronic pen client 22 sends a new grid reply to the electronic pen 10, wherein the reply contains an empty grid description with a grid exception. As a result, the electronic pen client 22 returns to the no application loaded state 80.
  • the electronic pen client 22 sends a request to the application server 30 to retrieve the application description (i.e., in accordance with the get application description procedure) . Accordingly, the electronic pen client 22 enters a waiting for application description state 90. If the electronic pen client 22 does not receive an application description from the application server 30 (as indicated at 92) , a new grid reply is sent by the electronic pen client 22 to the electronic pen 10 wherein the reply contains an empty grid. Thus, the electronic pen client 22 returns to the no application loaded state 80.
  • the electronic pen client 22 If, however, the electronic pen client 22 does receive an application description from the application server 30 (as indicated at 94) , the electronic pen client 22 sends a new grid reply to the electronic pen 10 containing a new grid description, and the electronic pen client 22 loads the application in its memory. In addition, the electronic pen client 22 moves into an application loaded state 96. In the application loaded state 96, five types of actions can be received by the electronic pen client 22 from the electronic pen 10. First, a received action can include a request that the electronic pen client 22 cannot handle itself, in which case the electronic pen client 22 will send the action to the base translator 28 (as indicated at 98) . The electronic pen client 22 then moves into a waiting for response from the base translator state 100. Once a base translator response 102 is received by the electronic pen client 22, the electronic pen client 22 updates a current form or other data associated with the currently loaded application and sends an action reply to the electronic pen 10 with appropriate output information.
  • Another type of action that the electronic pen client 22 can receive from the electronic pen 10 is a request that should be forwarded to a control node 24.
  • the action is sent to a control URL specified in the application description (as indicated at 104), and the electronic pen client 22 enters a waiting for response from the control state 106.
  • the electronic pen client 22 sends an action reply to the electronic pen 10 with appropriate output information.
  • a third type of action is a submit form request, in response to which the electronic pen client 22 will submit the current form to the application server 30 that is identified by the URL in the application description (as indicated at 110) .
  • the electronic pen client 22 then enters a waiting for response from the application server state 112. If the application server 30 responds by sending an empty application description to the electronic pen client 22 (as indicated at 114), the current application is unloaded from the electronic pen client 22 and an action reply is sent to the electronic pen 10 with an empty grid. As a result, the electronic pen client 22 returns to the no application loaded state 80.
  • the application server 30 responds with a non-empty application description
  • the old application is unloaded from the electronic pen client 22
  • the new application description is parsed and loaded in the electronic pen client 22
  • an action reply is sent to the electronic pen 10 with a new grid description and with appropriate output information
  • the electronic pen client 22 returns to the application loaded state 96.
  • a fourth type of action that can be received by the electronic pen client 22 from the electronic pen 10 is a request to load a new grid. This action occurs, for example, when a position outside of the current grid is detected by the electronic pen 10.
  • the electronic pen client 22 sends a request to the name server 26 (as indicated at 116) and the electronic pen client 22 returns to the waiting for application description URL state 84.
  • a fifth type of action that can be received by the electronic pen client 22 is an action that the electronic pen client 22 can handle itself, in which case the electronic pen client 22 updates the current form and sends an action reply to the electronic pen 10 with appropriate output information (as indicated at 118) .
  • the electronic pen client 22 then remains in the application loaded state 96.
  • One type of action that the electronic pen client 22 might be able to handle itself is a local application.
  • the electronic pen client 22 might be capable of performing certain basic functions that are defined by a local application.
  • the electronic pen client 22 can load the application description from its local memory, send a new grid description to the electronic pen 10 without having to communicate with the name server 26 or the application server 30.
  • Another action that might be handled locally by the electronic pen client 22 relates to the selection of fields within a form.
  • the electronic pen client 22 receives an action, the field that corresponds to that action receives focus.
  • the electronic pen client 22 might display the field' s value on its display or output the value by audio.
  • the electronic pen client 22 might allow the user to edit the value of the field by means other than the electronic pen 10.
  • Yet another type of action that might be handled by the electronic pen client 22 itself are actions that relate to a clipboard function. When a "copy" field is selected, the value of the field that had focus at the time the copy field was selected is transferred to the clipboard. Similarly, when a "paste" field is selected, the value stored in the clipboard is transferred to the field that had focus at the time the paste field was selected.
  • FIGURES 10A through 10C there is shown, by way of example, a message flow and signaling diagram illustrating the operation of the electronic pen system 2 depicted in and discussed in connection with FIGURE 2.
  • the electronic pen 10 detects a first position on the address pattern at step 120 (e.g., at a location on a sheet of paper designated for composing and sending emails) .
  • the electronic pen 10 is in a no grid loaded state.
  • the electronic pen 10 sends a new grid request 122, which contains the detected position information, to the electronic pen client 22.
  • the electronic pen client 22 sends an application location request 124 containing the detected position information to the name server 26, at step 126.
  • the name server 26 translates the detected position into a URL where an application description that corresponds to the detected position can be found (e.g., a URL address for a server containing an email application) , and returns an application location reply 128 containing the retrieved URL to the electronic pen client 22.
  • the electronic pen client 22 then sends an application description request 130, which contains the unique pen ID for the electronic pen 10, to the application server 30.
  • the application server 30 retrieves the application description at step 132 and sends an application description reply 134 containing the retrieved application description to the electronic pen client 22.
  • the electronic pen client 22 then parses and stores the application description at step 136. This step further involves generating a current grid description from the application description and sending the grid description to the electronic pen 10 in a new grid reply 138.
  • the electronic pen 10 stores the received grid description at step 140 and resumes processing of the detected positions. Using the detected positions and the information in the grid description (e.g., so that the electronic pen 10 knows which fields of the email form are being filled in) , the electronic pen 10 generates strokes at step 142 and generates actions at step 144 using the stroke engine 52 and action engine 56 shown in FIGURE 7. Each time an action is generated that cannot be handled by the electronic pen 10 itself, an action request 146 containing a description of the action is sent from the electronic pen 10 to the electronic pen client 22. At this point, the electronic pen client 22 should determine what type of action has been received so that it can respond to the action in an appropriate manner.
  • the electronic pen client 22 should determine what type of action has been received so that it can respond to the action in an appropriate manner.
  • a local application it is determined whether the action requires the attention of, or otherwise should be processed in accordance with, a local application at step 148.
  • Very basic applications or frequently used applications e.g., delete entered text
  • the electronic pen client 22 retrieves the local application at step 150 and sends an action reply 152, which can contain a new grid description or other appropriate information.
  • step 148 it is determined whether the received action requires processing by an external translator (e.g., handwriting recognition) . If so, an action request 156 containing a description of the action is sent by the electronic pen client 22 to the base translator 28.
  • the base translator 28 processes the action at step 158 and sends an action reply 160 containing output information responsive to the received action (e.g., text corresponding to written characters) to the electronic pen client 22, which can forward the output information to the electronic pen 10 in an action reply 162, if necessary.
  • an external translator e.g., handwriting recognition
  • step 154 If it is determined at step 154 that the received action does not require processing by an external translator, it is next determined whether the action relates to a control application at step 164. If so, an action request 166 containing a description of the action is sent by the electronic pen client 22 to the control server 24.
  • the control server 24 processes the received action at step 168 and, if a response is necessary, returns output information responsive to the received action in an action reply 170, which is forwarded from the electronic pen client 22 to the electronic pen 10 in an action reply 172.
  • step 164 it is next determined whether the action comprises a request to submit a form at step 174 (e.g., a selection of a "send" area on the email form) . If so, an action request 176 containing the data entered onto the form is sent by the electronic pen client 22 to the application server 30.
  • the application server 30 processes the form at step 178 and sends an action reply 180 containing a new application description (or an empty application description) to the electronic pen client 22.
  • the electronic pen client 22 parses and stores the new application description at step 182 and generates a new grid description from the newly received application description.
  • the electronic pen client 22 then sends an action reply 184 containing the new grid description.
  • the electronic pen 10 will typically respond to the receipt of a new grid description by unloading its current grid description and loading the new grid description into its memory.
  • the electronic pen 10 detects a position that is outside of the currently loaded grid at step 186. In response to such an event, the electronic pen 10 sends a new grid request 188 containing the newly detected position data to the electronic pen client 22. In response, the electronic pen client 22 again generates an application location request 190 containing the detected position data and sends the request to the name server 26. The name server 26 determines whether a URL for an application description that corresponds to the newly detected position is available at step 192.
  • the name server 26 sends an application location reply 194 containing a retrieved URL to the electronic pen client 22, which in turn sends an application description request 196 containing the unique pen ID for the electronic pen 10 to the application server 30 at the identified URL address, just as previously discussed in connection with messages 128 and 130.
  • the application server 30 determines that the requested application description is unavailable at step 198.
  • the application server 30 sends an application description reply to the electronic pen client 22 containing an empty application description.
  • the electronic pen client 22 unloads the current application at step 202 and sends a new grid reply 204 containing an empty grid description to the electronic pen 10.
  • the electronic pen 10 responds to the receipt of the empty grid description by unloading the current grid description at step 206.
  • the name server 26 determines at step 192 that a URL corresponding to the detected porition is not available.
  • the name server 26 sends an application location reply 208 to the electronic pen client 22.
  • the reply 208 may simply be empty to indicate that a URL is not available.
  • the reply 208 contains a grid exception defining the largest area possible around the detected position for which there is no corresponding URL.
  • the electronic pen client 22 sends a new grid reply 210 containing an empty grid description with a grid exception.
  • the electronic pen 10 unloads the current grid description at step 212.
  • the electronic pen 10 may subsequently be able to determine that certain detected positions on the address pattern are not associated with any application without having to send a request to the name server 26 or the application server 30.
  • an electronic pen 10 or other electronic reading device can be used in connection with a client device 22 that includes an electronic MMI for enhancing interactions involving the electronic pen 10.
  • the client device 22 might comprise a mobile phone.
  • the mobile phone's MMI can be used for accessing and configuring the electronic pen 10.
  • the electronic pen 10 can be used in connection with an addressed surface to provide an input MMI, while the phone MMI can be used to provide output (feedback to the user) and other types of input.
  • FIGURE 11 there is illustrated a message flow and signaling diagram for configuring and accessing pages in an electronic pen 10 using a wireless application protocol (WAP) browser in a mobile phone 14 in accordance with one embodiment of the present invention.
  • the electronic pen 10 contains a WAP server, while the mobile phone 14 includes a WAP client.
  • the WAP client in the mobile phone 14 sends a request message 220 to the WAP server in the electronic pen 10 requesting a particular WAP page (e.g., a configuration page) .
  • the WAP server responds by returning the requested page in a response message 222.
  • the WAP client displays the page at step 224 on a mobile phone display screen.
  • a user selects a link displayed on the display screen using the mobile phone MMI (e.g. , a mobile phone keypad or soft keys) .
  • the WAP client sends another request message 228 that contains a common gateway interface (CGI) call to the WAP server, which executes the CGI call at step 230.
  • CGI common gateway interface
  • the mobile phone 14 can be utilized as an MMI for configuring the electronic pen 10.
  • FIGURE 12 there is illustrated a message flow and signaling diagram for configuring an electronic pen 10 using an application program interface (API) for a mobile phone MMI (e.g., for generating dynamic menus) in accordance with another embodiment of the present invention.
  • API application program interface
  • the electronic pen 10 sends a create menu message 232 formatted pursuant to the mobile phone MMI API and containing, for example, menu choices to be displayed.
  • the mobile phone 14 displays a menu at step 234.
  • a user selects a menu option at step 236 using the mobile phone MMI, and the mobile phone 14 sends a user choice message
  • the electronic pen 10 executes a function that corresponds to the user selection at step 240.
  • the electronic pen 10 includes a WAP server while the mobile phone 14 includes a WAP client.
  • An application graphical user interface (GUI) is contained on an addressed surface 12.
  • GUI graphical user interface
  • the electronic pen 10 then forwards an indication 244 that the address book field has been checked to a network 2 that contains an application engine associated with the application GUI contained on the addressed surface 12.
  • an application server 30 associated with the application GUI stores instructions for responding to detected portions of the application GUI.
  • the application server 30 sends (e.g., using a WAP push) a message 246 containing a WAP page that links to the requested address book.
  • the retrieved WAP page is displayed on a display screen of the mobile phone 14 at step 248.
  • the user selects the address book link at step 250 either by checking an appropriate field on the addressed surface 12 with the electronic pen 10 or by inputting the selection via a mobile phone MMI .
  • a CGI call is sent either from the mobile phone 14 (as indicated at 252) or from the electronic pen 10 in response to the selection of the appropriate field on the address pattern 12 (as indicated at 254).
  • the mobile phone 14 and the electronic pen 10 can each have a unique IP address, wherein the mobile phone 14 acts as a router.
  • the mobile phone 14 acts as a router.
  • the phone acts as a proxy towards the electronic pen 10.
  • the application in this and all subsequent embodiments is described as being supported by an application server 30, support for the application could also be located in the electronic pen 10 or the mobile phone 14 instead of in the network 2.
  • the network-based application could use internal mobile phone 14 or electronic pen 10 functions (e.g., a phone book) via a WAP or AT based API.
  • SMS short message service
  • the network-based application could allow the user to interact with a phone book stored inside the mobile phone 14.
  • FIGURE 14 there is illustrated a message flow and signaling diagram for providing application interaction using WAP communications wherein the electronic pen 10 acts as a proxy towards the mobile phone 14 in accordance with an alternative embodiment of the invention.
  • the electronic pen 10 is the only device with a unique IP address.
  • the mobile phone 14 accesses the electronic pen 10 using WAP communications over a Bluetooth radio interface.
  • the mobile phone 14 accesses the network 2 via the electronic pen proxy.
  • the electronic pen 10 can be connected to the network 2 either via the mobile phone 14 (e.g., using general packet radio service (GPRS) provided by the mobile phone 14) or via another Bluetooth access point.
  • GPRS general packet radio service
  • the electronic pen 10 When the electronic pen 10 is used to select an address book field, the electronic pen 10 detects a portion of the address book field as indicated as 242. An indication 244 that the address book field has been selected is then forwarded by the electronic pen 10 to the application server 30. In response, a message 256 containing a WAP page that links to the requested address book is sent to the electronic pen' s unique IP address. The electronic pen 10 forwards the received WAP page to the mobile phone 14 in a message 258. The mobile phone 14 displays the WAP page on a display screen at 260. At step 262, a user selects the address book link, and in response, a CGI call 264 is sent by the mobile phone 14 to the electronic pen 10, which forwards the CGI call to the application server 30 in a message 266.
  • FIGURE 15 there is illustrated a message flow and signaling diagram for supporting application interaction via AT commands between an electronic pen 10, a mobile phone 14, and an application server 30 in accordance with yet another embodiment of the invention.
  • an indication 244 that the address book field has been selected is sent by the electronic pen 10 to the application server 30.
  • the application server 30 responds by sending a message 268 that contains a link to WAP page X, which links to the requested address book.
  • the electronic pen 10 responds to the message 268 by sending an AT command 270 to the mobile phone 14 requesting that the mobile 14 start its WAP browser on page X.
  • the WAP browser is started at step 272, and a request for page X is sent in a message 274 to the application server 30.
  • the application server 30 retrieves the requested page and sends a message 276 containing page X to the WAP browser in the mobile phone 14.
  • the user selects the link to the address book using the mobile phone MMI, and a CGI call 278 is sent by the mobile phone 14 to the application server 30.
  • the start of the WAP browser is requested via the electronic pen 10.
  • the illustrated example invokes a WAP session that uses direct communications between the mobile phone 14 and the network 2 (as is also illustrated in FIGURE 13)
  • the WAP session could also involve communications via an electronic pen proxy (as illustrated in FIGURE 14) .
  • FIGURE 16 there is illustrated a message flow signaling diagram for providing application interaction using AT commands to create dynamic menus in accordance with another embodiment of the present invention.
  • a protocol that maps menu content to the dynamic menus in the mobile phone 14 is implemented in the application server 30.
  • the electronic pen 10 could then provide an exact mapping or a higher level mapping, which would offer the application more advanced functions.
  • the electronic pen 10 could also offer a WAP dynamic menus converter.
  • an indication 244 that the address book field has been selected is sent by the electronic pen 10 to the application server 30.
  • the application server 30 sends a request 280 to the electronic pen 10 to create a menu on the mobile phone 14.
  • the request 280 includes the intended content of the menu to be created.
  • the electronic pen 10 then sends an AT command to the mobile phone 14 to create a menu on the mobile phone 14.
  • a menu is displayed on a display screen of the mobile phone 14 at step 284.
  • the user chooses a selection from the menu at step 286 using either the mobile phone MMI or the addressed paper 12 MMI .
  • the user choice is either forwarded by the mobile phone 14 to the electronic pen 10 as indicated at 288 or is detected as a result of the electronic pen 10 being used to select an appropriate field on the addressed paper 12 as indicated at 292. In either case, the user choice is forwarded to the application server 30 by the electronic pen 10 in a message 292.
  • an FIFO buffer 38 stores detected positions in the electronic reading device 10.
  • a new position .e., a position that is not within the currently loaded grid description
  • a request is sent to the name server 26 to retrieve a URL address where an application associated with positions at and around the detected position is stored.
  • the electronic reading device 10 might be used on a portion of the address pattern that is not associated with any application.
  • the name server 26 would not be able to identify an appropriate URL address nor could a grid description containing the detected position be retrieved.
  • situations might arise in which the electronic reading device 10 is temporarily unable to contact the name server 26 or application server 30.
  • the electronic reading device 10 would not typically be capable of determining whether positions stored in the FIFO buffer 38 are associated with one another. As a result, the electronic reading device 10 might waste time and communication resources repeatedly contacting the name server 26 for each and every position contained in the FIFO buffer 38. Furthermore, without being able to associate different positions with one another, the electronic reading device 10 would not be able to efficiently delete or otherwise manipulate the various positions stored in the FIFO buffer 38.
  • positions on the address pattern can be grouped in a way that makes it possible for the electronic reading device 10 to identify the grouping without communicating with other entities in overall system 2.
  • the overall address space it is possible for the overall address space to have a size of 73,000,000,000,000 A4 pages. Locations on such an address space can be identified using an x-coordinate value and a y- coordinate value of 64 bits each, which means that each position on the address pattern can be uniquely identified by a 128 bit code.
  • the electronic reading device 10 can immediately determine the x-coordinate and y-coordinate values using information stored in the electronic reading device memory. This can be achieved, for example, by processing a detected portion of a pattern of dots using an algorithm stored in the electronic reading device 10 to generate the precise x- coordinate and y-coordinate 64-bit values.
  • the present invention uses two bits (e.g. , the two most significant or two least significant bits) from each coordinate to identify an application class.
  • the overall address space will be addressable with four bits less of information, making the address space 16 times smaller than in the case of a 64 * 64 bit addressable area.
  • the name server 26 will then identify URL addresses for associated applications based upon a 62 * 62 bit address scheme, although the full 64 * 64 bit address space will still be available. The difference is that the upper four bits of the address space will be used for identifying an application class.
  • the electronic reading device will typically detect an area of the address pattern and process the detected pattern of dots using a stored algorithm to identify a unique 64-bit x-coordinate value and a unique 64- bit y-coordinate value.
  • the electronic reading device 10 will then send the coordinate values to the name server 26 for use in retrieving grid and/or application descriptions.
  • the full 64 * 64 bit address can be sent by the electronic reading device 10, it is contemplated that the two bits from each 64-bit coordinate value that are used for identifying the application class are not needed by the name server 26 or application server 30.
  • the electronic reading device 10 might only send a 62 x 62 bit address.
  • the remaining 2 x 2 bits are then used by the electronic reading device 10 for identifying an application class.
  • an application developer is allocated a sub-address space (i.e., a portion of the overall address space) from the 62 * 62 bit addressed area.
  • the application developer sets the upper 2 * 2 bits based on which application class is selected.
  • the allocated sub-address space includes a portion of a larger pattern of dots. A position on the larger patten of dots can be identified to within a resolution of 62 x 6? oits.
  • the application developer then identifies the selected application class of the sub-address space by adding additional dots that provide an additional 2 * 2 bits of information.
  • the application developer selects a portion of the overall 64 64 bit address pattern that includes both the allocated portion of the 62 * 62 bit sub-address space and the selected 2 x 2 bit application class.
  • the application developer selects a portion of the overall 64 64 bit address pattern that includes both the allocated portion of the 62 * 62 bit sub-address space and the selected 2 x 2 bit application class.
  • By allocating sections of the overall address pattern based only on 62-bits of x-coordinates and 62-bits of y-coordinates it will be recognized that each 62 x 62 bit address will be repeated 16 times in the overall 64 * 64 bit address pattern.
  • the application developer can simply select one of the 16 repetitions of the 62 ⁇ 62 bit address pattern according to which application class, and thus what additional 2 * 2 bits of information, is desired.
  • each application class has a predefined specific size and always starts at a specific even offset (e.g., n times size, where n is an integer) .
  • an application class identified by the four bits "0000” might be predefined as having a size of 10 10 positions and would always start at even ten positions (i.e., positions where the x-coordinate value and the y-coordinate value are each divisible by ten)
  • an application class identified by the four bits "0001” might have a size of 100 * 100 positions and start at even 100 positions
  • an application class identified by the four bits "0010” might have a size of 1,000 1,000 positions and start at even 1,000 positions
  • an application class identified by the four bits "0011” might be predefined as having a size of 10,000 * 10,000 positions and start at even 10,000 positions, and so forth up to an application class identified by the four bits "llll”.
  • an area of 10,000 10,000 bits can include varying numbers of applications depending on which application class is selected.
  • the area could include one application with an application class of "0011", 100 applications with an application class of "0010", 10,000 applications with an application class of "0001", and so forth.
  • the larger the application class the more space the application has available and thus the more functionalities and/or information that can be supported by the application .
  • the preferred embodiment utilizes 16 different application classes, it will be understood that other application class formats can also be used.
  • other numbers of application classes, other numbers of bits used to define the application class, and other sizes and starting positions for each application class can be used.
  • the upper one * one bits of information might be used to identify the application class, which would allow a 63 63 bit address space to be defined in the name server 26 but would allow only four different application classes.
  • the smallest application class might be 100 * 100 positions, or the application classes might represent areas that are rectangular rather than square. In any event, an application developer can preferably only assign one application to each group of positions within an application class.
  • the electronic reading device 10 can easily determine which positions in the FIFO buffer 38 belong together.
  • the electronic reading device 10 has the ability to move, delete, or process groups of positions that belong to the same application rather than simply moving, deleting, or processing each position one at a time.
  • the electronic reading device 10 can perform such a function without having to communicate with other entities in the system 2.
  • Such an ability to identify groups of positions can be useful in a variety of situations. For example, if a position is detected with the electronic reading device 10 for which the name server 26 has no associated application, an empty grid description will be returned to the electronic reading device 10 indicating that the detected position has no associated application. Subsequently, the electronic reading device 10 can identify other positions that belong to the same group as the initially detected position to determine that the subsequently detected positions also have no associated application. The entire group of positions can then be deleted or stored accordingly. This ability to identify groups avoids having to contact the name server 26 for each different detected position. Instead, the electronic reading device 10 can use knowledge about one position within the group to deduce information about or characteristics of other positions within the group.
  • positions detected by the electronic reading device 10 can be grouped together based on the electronic reading device's knowledge of the application class for the positions, the size of the application class, and the starting position of the application class. The entire group of detected positions can then be deleted or stored together for use at a later time when the electronic reading device 10 is able to contact the name server 26.
  • FIGURE 17 there is illustrated a schematic diagram of an area 300 of the address space in accordance with the present invention.
  • the illustrated portion of the address space 300 which is represented by ⁇ [5000, 5000], [7000, 8000] ⁇ (i.e., ⁇ (x m ⁇ n , y min ) , (x max , y max ) ⁇ ) , is allocated to a particular application developer and has a resolution of 62 * 62 bits.
  • the application developer is then responsible for setting the upper four bits of information to an appropriate value (e.g., by adding 2 * 2 bits of information to the address pattern) .
  • the application developer sets the application class to "0001" in the area bounded by ⁇ [5000, 5000], [6000, 6000] ⁇ and in the area bounded by ⁇ [6000, 6000], [7000, 7000] ⁇ and sets the application class to "0010" in the area bounded by ⁇ [6000, 5000], [7000, 6000] ⁇ , in the area bounded by ⁇ [5000, 6000], [6000, 7000] ⁇ , in the area bounded by ⁇ [5000, 7000], [6000, 8000] ⁇ , and in the area bounded by ⁇ [6000, 7000], [7000, 8000] ⁇ .
  • the portions of the sub-address space that are assigned to application class "0001" are dividt J into 100 separate groupings 302 of positions.
  • Each grouping or box 302 can then be associated with one application such that the area can be used for up to 100 different applications.
  • all of the positions within each box 302 are known to belong to the same group and thus the same application.
  • portions of the sub-address space assigned to application class "0010" have a size of 1000 x 1000 positions and thus each of the four illustrated groupings 304 can only contain one application.
  • the positions within each of the four i.Mustrated groupings 304 are known to be associated with th. same application.
  • an electronic reading device 10 When an electronic reading device 10 detects a specific position 306 within a portion of the sub-address space assigned to application class 0010", the electronic reading device 10 will attempt to retrieve a grid description for an area that contains the specific position 306. If a grid description cannot be retrieved or if it is determined that no application is associated with the specific position 306, the electronic reading device 10 can identify the application class to which the specific position 306 belongs by examining the upper 2 x 2 bits of information. If the electronic reading device 10 subsequently detects additional positions, the electronic reading device 10 can determine which of those positions belong to the same application by determining whether the subsequently detected positions are within the same grouping 304, which is identified in this instance by ⁇ [5000, 6000], [6000, 7000] ⁇ .
  • the electronic reading device 10 can then delete such positions from its FIFO buffer 38 or it can move the positions to another storage area (e.g., in the electronic reading device 10 or client device 22) for later use.
  • the electronic reading device 10 might first request a user authorization to delete or move the positions.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Signal Processing (AREA)
  • Databases & Information Systems (AREA)
  • Multimedia (AREA)
  • Software Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • User Interface Of Digital Computer (AREA)
  • Position Input By Displaying (AREA)
EP01913802A 2000-02-16 2001-02-09 System und verfahren zum betreiben einer benutzerschnittstelle mit einer elektronischen lesevorrichtung Withdrawn EP1256048A2 (de)

Applications Claiming Priority (11)

Application Number Priority Date Filing Date Title
US703506 1991-05-21
US18274200P 2000-02-16 2000-02-16
US182742P 2000-02-16
US19034300P 2000-03-16 2000-03-16
US190343P 2000-03-16
US19266200P 2000-03-28 2000-03-28
US192662P 2000-03-28
US70348000A 2000-10-31 2000-10-31
US09/703,506 US6611259B1 (en) 2000-02-16 2000-10-31 System and method for operating an electronic reading device user interface
US703480 2000-10-31
PCT/EP2001/001400 WO2001061450A2 (en) 2000-02-16 2001-02-09 A system and method for operating an electronic reading device user interface

Publications (1)

Publication Number Publication Date
EP1256048A2 true EP1256048A2 (de) 2002-11-13

Family

ID=27539078

Family Applications (1)

Application Number Title Priority Date Filing Date
EP01913802A Withdrawn EP1256048A2 (de) 2000-02-16 2001-02-09 System und verfahren zum betreiben einer benutzerschnittstelle mit einer elektronischen lesevorrichtung

Country Status (3)

Country Link
EP (1) EP1256048A2 (de)
AU (1) AU3925401A (de)
WO (1) WO2001061450A2 (de)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SE517445C2 (sv) 1999-10-01 2002-06-04 Anoto Ab Positionsbestämning på en yta försedd med ett positionskodningsmönster
US20030061188A1 (en) 1999-12-23 2003-03-27 Linus Wiebe General information management system
US6958747B2 (en) 2000-08-30 2005-10-25 Anoto Ab Method for making a product
SE523112C2 (sv) 2001-07-05 2004-03-30 Anoto Ab Förfaringssätt för kommunikation mellan en användarenhet som har möjlighet att läsa information från en yta, och servrar som exekverar tjänster som stöder användarenheten
FR2853114A1 (fr) * 2003-03-26 2004-10-01 France Telecom Dispositif de transmission sur un reseau d'informations acquises par un appareil de telecommunication distant et systeme mettant en oeuvre un tel dispositif.
SE0303058D0 (sv) 2003-11-18 2003-11-18 Anoto Ab Methods and arrangemang in an information management system

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5852434A (en) * 1992-04-03 1998-12-22 Sekendur; Oral F. Absolute optical position determination
US6072917A (en) * 1995-08-03 2000-06-06 Olympus Optical Co., Ltd. Code sheet and information reproduction apparatus

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5905248A (en) * 1990-09-11 1999-05-18 Metrologic Instruments, Inc. System and method for carrying out information-related transactions using web documents embodying transaction enabling applets automatically launched and executed in response to reading URL-encoded symbols pointing thereto
US5477012A (en) * 1992-04-03 1995-12-19 Sekendur; Oral F. Optical position determination
US5661506A (en) * 1994-11-10 1997-08-26 Sia Technology Corporation Pen and paper information recording system using an imaging pen
CA2331073A1 (en) * 1998-04-30 1999-11-25 C Technologies Ab Input unit, method for using the same and input system

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5852434A (en) * 1992-04-03 1998-12-22 Sekendur; Oral F. Absolute optical position determination
US6072917A (en) * 1995-08-03 2000-06-06 Olympus Optical Co., Ltd. Code sheet and information reproduction apparatus

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
DYMETMAN M ET AL: "Intelligent Paper", LECTURE NOTES IN COMPUTER SCIENCE/COMPUTATIONAL SCIENCE > (EUROCRYPT )CHES 2002, SPRINGER, DE, vol. 1375, 30 March 1998 (1998-03-30), pages 392 - 406, XP002328425, ISBN: 978-3-540-24128-7, DOI: 10.1007/BFB0053286 *

Also Published As

Publication number Publication date
WO2001061450A3 (en) 2002-01-10
WO2001061450A2 (en) 2001-08-23
AU3925401A (en) 2001-08-27

Similar Documents

Publication Publication Date Title
US6611259B1 (en) System and method for operating an electronic reading device user interface
US6832116B1 (en) Method and system for controlling an electronic utility device using an electronic reading device
US6885878B1 (en) Method and system for using an electronic reading device as a general application input and navigation interface
US6593908B1 (en) Method and system for using an electronic reading device on non-paper devices
US6738053B1 (en) Predefined electronic pen applications in specially formatted paper
US6952497B1 (en) Method and system for electronically recording transactions and performing security function
US6698660B2 (en) Electronic recording and communication of information
EP1256091B1 (de) Verfahren und system zur konfiguration und zum deblockieren einer elektronischen vorrichtung
WO2001061449A2 (en) Specially formatted paper based applications of a mobile phone
US6813396B1 (en) Method for sharing information between electronic reading devices
KR20100013539A (ko) 휴대용 단말기에서 패턴 인식을 이용한 사용자 인터페이스장치 및 방법
EP1264270B1 (de) Stiftdrucker
EP1257965B1 (de) Elektronischer griffel mit ein/aus tintenfunktion und kontakterkennungsfunktion mit dem papier
US6839623B1 (en) Positioning applications for an electronic reading device
US6693623B1 (en) Measuring applications for an electronic reading device
US20010033293A1 (en) Electronic pen help feedback and information retrieval
EP1256090B1 (de) Elektronischer schreiber für elektronischen handel
EP1256048A2 (de) System und verfahren zum betreiben einer benutzerschnittstelle mit einer elektronischen lesevorrichtung
EP1256088A2 (de) Elektronischer schreibstift mit hilfe-rückmeldung und informationsauffindung
JP2004508632A (ja) 情報の電子的な記録と通信
WO2001061451A2 (en) Multi-layer reading device

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 20020823

AK Designated contracting states

Kind code of ref document: A2

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE TR

AX Request for extension of the european patent

Free format text: AL PAYMENT 20020823;LT PAYMENT 20020823;LV PAYMENT 20020823;MK PAYMENT 20020823;RO PAYMENT 20020823;SI PAYMENT 20020823

RAP1 Party data changed (applicant data changed or rights of an application transferred)

Owner name: TELEFONAKTIEBOLAGET LM ERICSSON (PUBL)

17Q First examination report despatched

Effective date: 20120307

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 20150106