MOBILE TERMINAL AND PROGRAM

Abstract
The environment around mobile phone handset 10 is judged according to the number of other mobile phone handsets present near mobile phone handset 10 and the registration status of the nearby telephones. Then, the display sequence of function names on a function selection screen is changed according to the environment. As a result, functions deemed likely to be selected by the user based on the environment surrounding mobile phone handset 10 may be displayed at positions where they may be selected with fewer operations. In this way, the number of operations required of the user for selecting any of multiple functions may be reduced.
Description
TECHNICAL FIELD

The present invention relates to technology for enabling a user to select any of multiple functions implemented by a mobile terminal.


BACKGROUND ART

Mobile phone handsets, which have become widely used in recent years, are provided with various functions. Examples of basic functions include functions for adjusting a ringtone volume when a call is received. More complicated functions include functions for exchanging electronic business-card data between multiple mobile phone handsets or purchasing goods using electronic money stored in a mobile phone handset. When a user selects a desired function from among these multiple functions, first, a function selection screen listing the function names is displayed on the mobile phone handset, after which a desired function is selected from the function selection screen.


It is desirable that in selecting a desired function the user is required to perform as few selection operations as possible; and it is therefore important in arranging the function names on a screen to take such usability into account. For example, when the function names are displayed on the function selection screen, if one or more of the function names that is likely to be selected by the user can be arranged at a default position at which the cursor for selecting a function is displayed (typically at the top of the function selection screen), such positioning is likely to reduce or eliminate a need for the user to move the cursor to select the one or more commonly selected function names. With this object in mind, Patent Document 1 discloses a technology that records a frequency of use of each of a function and sets a display so that functions that are most frequently used may be selected by use of relatively few operations.


DISCLOSURE OF THE INVENTION
Problem to be solved by the Invention

It is not possible to predict which function the user will select in each and every situation based solely on past use frequency. Therefore, the purpose of the present invention is to provide a new approach to reducing the number of operations required of the user when selecting any of multiple functions implemented by a mobile terminal.


Means for Solving the Problem

To solve the above problems, the present invention provides a mobile terminal that includes: a display control unit that displays, on a display, a function selection screen on which a plurality of function names are arranged in accordance with a given sequence; a selection operation unit that accepts an operation for selecting any of the function names arranged on the function selection screen; an implementation unit that implements the function with the name selected through the operation accepted by the selection operation unit; a detection unit that detects another mobile terminal present within a given distance from a position of the mobile terminal; and a determination unit that determines different sequences to be complied with by the display control unit for a case in which other mobile terminals are detected by the detection unit, and for a case in which other mobile terminals are not detected by the detection unit.


According to an aspect of the present invention, when another mobile terminals are detected by the detection unit, the function names are displayed in an appropriate sequence, and as a result, a number of operations required to be carried out by the user in selecting a desired one of any of multiple functions can be reduced.


In an exemplary mode of the present invention, the detection unit determines a number of other mobile terminals present within the given distance from the position of the mobile terminal; and the determination unit determines the sequence depending on the number of other mobile terminals determined by the detection unit. Another exemplary mode further includes an identification information memory that stores identification information assigned to the detected other mobile terminals, other than the mobile terminal, wherein: the detection unit determines the identification information assigned to the detected other mobile terminals present within the given distance from the position of the mobile terminal; and the determination unit determines the sequence differently for a case in which the identification information determined by the detection unit matches the information stored in the identification information memory, and a case in which the identification information determined by the detection unit does not match the information stored in the identification information memory.


As a result, the function names are displayed in a sequence appropriate for the situation in accordance with the number of other mobile phone handsets determined and whether information of the detected other mobile phone handsets has already been stored.


Typically, the determination unit includes: an environment definition memory that stores information detected by the detection unit and an environment class assigned to each of a plurality of environments defined in advance as environments of the mobile terminal; a function memory that stores function identification information assigned to each of the functions and the environment classes; an environment specification unit that specifies the environment class that is associated with the information detected by the detection unit and stored in the environment definition memory; and a function specification unit that specifies function identification information that is associated with the environment class specified by the environment specification unit and stored in the function memory, and determines the sequence to arrange the function name assigned to the function identification information specified by the function specification unit at a position where the function name is selectable by use of fewer operation selection steps than are required to be used for selection of other of the function names.


In this case, if the environment specification unit specifies a plurality of environment classes, the determination unit specifies an order of precedence for each of the plurality of environment classes according to a weighting assigned to each of the plurality of environment classes, and determines the sequence according to the specified order of precedence.


With this configuration, even when multiple environments are specified, the function names can be displayed in an appropriate sequence.


Moreover, the exemplary mode may include: a modification operation unit that accepts operations for modifying the sequence determined by the determination unit; and a modified-content memory that stores content modified through the operations accepted by the modification operation unit, wherein the determination unit determines the sequence according to the content stored in the modified-content memory.


As a result, the display sequence may be set according to the user's intentions.


The exemplary mode of the present invention includes: an acquisition unit that acquires a program describing the steps for implementing the function using the implementation unit along with the content stored in the environment definition memory or the function memory; and an update unit that updates the content stored in the environment definition memory or the function memory according to the content described in the program acquired by the acquisition unit.


In this way, the content stored in the environment definition memory or the function memory may be updated according to the intentions of the program provider.


Moreover, another exemplary mode of the present invention includes a reception unit that, when function identification information assigned to the function is transmitted from another mobile terminal detected by the detection unit, receives the function identification information, wherein the determination unit determines the sequence to arrange the function name to which the function identification information received by the reception unit has been assigned at a position where the function name is selectable by use of fewer operation selection steps than are required to be used for selection of other of the function names.


In this way, the function name of the function identification information transmitted from another mobile terminal present within a given distance from the position of the mobile terminal can be arranged at a position such that the function of the function name is selectable by the user by use of relatively few selection operations.


Moreover, the exemplary mode may also be set to include a user identification unit that identifies a user using the mobile terminal, wherein the determination unit determines the sequence for the user identified by the user identification unit. As a result, the display sequence of the function names can be changed for each user. Moreover, the exemplary mode may also be set to include an area specification unit that specifies an area in which the mobile terminal is located, wherein the determination unit determines the sequence for each area specified by the area specification unit. As a result, the display sequence of the function names can be changed for each area.


Moreover, the present invention provides a program causing a computer to function as: a display control unit that displays a function selection screen on which a plurality of function names are arranged in accordance with a given sequence, and that is used to select any of a plurality of function names; a detection unit that detects another mobile terminal present within a given distance from the position of the computer; and a determination unit that determines different sequences to be complied with by the display control unit for a case in which other mobile terminals are detected by the detection unit, and for a case in which other mobile terminals are not detected by the detection unit. According to an aspect of the present invention, when another mobile terminal is detected by the detection unit, the function names are displayed in a sequence appropriate to the situation, and as a result, a number of operations required to be carried out by the user for selecting a function may be reduced.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram showing the overall configuration of a system related to an exemplary embodiment of the present invention;



FIG. 2 is a block diagram showing the configuration of a mobile phone handset of the exemplary embodiment;



FIG. 3 is a diagram showing one example of the content of a telephone registration table stored by the mobile phone handset;



FIG. 4 is a diagram showing one example of the content of a table of environment definitions stored by the mobile phone handset;



FIG. 5 is a diagram showing one example of the content of a table of functions stored by the mobile phone handset;



FIG. 6 is a diagram showing a software configuration of the mobile phone handset;



FIG. 7 is a flowchart showing a process executed by the mobile phone handset;



FIG. 8 is a diagram showing one example of the content of a judgment table stored by the mobile phone handset;



FIG. 9 is a diagram showing one example of the content of a judgment table stored by the mobile phone handset;



FIG. 10 is a flowchart showing a process executed by the mobile phone handset;



FIG. 11 is a flowchart showing a process executed by the mobile phone handset; and



FIG. 12 is a diagram showing one example of a function selection screen displayed by the mobile phone handset.





DESCRIPTION OF REFERENCE SYMBOLS


10-1, 10-2, 10-3 to 10-n: mobile phone handset; 11: controller; 12: wireless communication section; 13: speech-processing section; 14: display; 15: operating section; 16: memory; 17: short-range wireless communication section; 100: mobile phone network.


BEST MODE FOR IMPLEMENTING THE INVENTION

An exemplary embodiment of the present invention will now be described.


(1) Overview of the Exemplary Embodiment

In the present exemplary embodiment, an environment in which a mobile phone handset is situated is evaluated and a determination is made as to a function of the handset that will likely be desired to be used by the user in view of the environment in which the phone is currently situated. Accordingly, the function name of the function that is likely desired to be used is displayed on a function selection screen at a position in which it can be selected by the user by carrying out relatively few selection operations. Specifically, a display sequence of the function names is changed depending on whether other mobile phone handsets are present near the user's mobile phone handset. Any mobile phone handsets that are present near the user's mobile phone handset (i.e., within a given distance from the position of the user's mobile phone handset) are hereinafter referred to as “proximate mobile phones.” Moreover, the term “display sequence” as used in this description refers to a display sequence that affects a number of operations required to be carried out by the user in selecting a function. For example, for a function selection screen in which a cursor is moved sequentially over a list of multiple function names to make a selection, the position within the function selection screen at which the cursor is first displayed is the uppermost display sequence, and the position requiring the greatest moving distance of the cursor from the first position is the lowermost display sequence. Moreover, when multiple function names are arranged on multiple function selection screens in fixed numbers and a desired function is selected by switching between the function selection screens, the function selection screen displayed first is the uppermost display sequence, and the function selection screen displayed last is the lowermost display sequence. In other words, the position requiring the lowest number of operations for selecting a function constitutes the uppermost display sequence and the position requiring the highest number of operations constitutes the lowermost display sequence.


Moreover, in the present exemplary embodiment, the display sequence of the function names is changed according to a number of proximate mobile phones. In addition, proximate mobile phones are divided into two types: those that have been registered in the user's mobile phone handset (the mobile phone handset displaying the function selection screen) and those that have not been registered in the user's mobile phone set. Registration status is another factor that is taken into account in changing the display sequence of the function names.


The following are examples of display sequences that are set in accordance with a specific surrounding environment.


(1-1) When There are No Proximate Mobile Phones

In this case, the user of the mobile phone handset is separated from other people and is alone. Consequently, on the function selection screen, function names for handling private information, such as E-mail or a scheduler, are prioritized and displayed. This “prioritized display” refers to displaying a function name at a position requiring fewer operations of the user for selection as described above.


(1-2) When There are Only 1-5 Unregistered Proximate Mobile Phones

In this type of environment, there is a possibility that the user may exchange business cards with strangers, for example. Moreover, this type of environment may be encountered when the user is standing before a cash register for making a payment at a store, for example. Therefore, on the function selection screen, a business-card-exchange function or a small-payment function is prioritized and displayed.


(1-3) When There are 6 or More Unregistered Proximate Mobile Phones or 16 or More Registered Proximate Mobile Phones

This type of environment suggests that the user is in a public area. Consequently, on the function selection screen, functions appropriate for public areas, such as functions for adjusting the ringtone volume, are prioritized and displayed.


(1-4) When There are Only 1-5 Registered Proximate Mobile Phones

In this type of environment, there is a highly possibility that the user is engaged in some type of cooperative activity with acquaintances. Consequently, functions for synchronizing shared information or for exchanging information, for example, are prioritized and displayed.


(1-5) When There are 6-15 Registered Nearby Telephones

In this type of environment, there is a high possibility that a large group of acquaintances will engage in a competitive game. Consequently, on the function selection screen, relevant game functions are prioritized and displayed.


(2) Details of the Exemplary Embodiment

Next, the exemplary embodiment will be described in detail.


(2-1) Configuration


FIG. 1 is a block diagram showing the overall configuration of a system related to the present exemplary embodiment. In FIG. 1, mobile phone network 100 is a communications network utilizing the PDC (Personal Digital Cellular) standard, the GSM (Global System for Mobile Communications) standard, or the IMT-2000 (International Mobile Telecommunication-2000) standard. Mobile phone handsets 10-1, 10-2, 10-3 to 10-n are each capable of implementing communications over an extremely wide range through mobile phone network 100. Moreover, mobile phone handsets 10-1, 10-2, 10-3 to 10-n can also implement wireless communication within a limited range with a radius of 10 m, for example, without utilizing mobile phone network 100. The former will be referred to as “wide-area communication” and the latter will be referred to as “short-range communication.” Wide-area communication includes, for example, telephone calls, E-mail, or the downloading and uploading of information and is used when implementing network functions. Short-range communication includes, for example, exchanging business cards and electronic money as well as synchronizing and exchanging information with other mobile phone handsets, and is used when implementing non-network local functions.



FIG. 1 illustrates area (short-range wireless area) RA, where mobile phone handset 10-2 is able to implement short-range communication. Mobile phone handsets present in short-range area RA are “nearby telephones” of mobile phone handset 10-2. In FIG. 1, mobile phone handsets 10-1, 10-3 are proximate mobile phones of mobile phone handset 10-2. As mobile phone handsets 10-1, 10-2, 10-3 to 10-n all have the same configurations and perform the same operations, in the following description, when there is no need to distinguish each handset, they will be collectively referred to as “mobile phone handset 10.”



FIG. 2 is a block diagram showing the configuration of mobile phone handset 10. As shown in FIG. 2, mobile phone handset 10 includes controller 11, wireless communication section 12, speech-processing section 13, display 14, operating section 15, memory 16, and short-range wireless communication section 17. Controller 11 includes, for example, a CPU (Central Processing Unit), a ROM (Read Only Memory), and a RAM (Random Access Memory) and controls each section of mobile phone handset 10. The ROM stores basic control programs (preinstalled programs to be described later) executed by the CPU.


Wireless communication section 12 includes antenna 121 and a wireless communication circuit that is not shown. When wireless communication section 21 receives a radio signal transmitted from a base station of mobile phone network 100 through antenna 121, it demodulates the signal using the wireless communication circuit and performs error correction and decoding processes. The error-corrected and decoded audio data undergoes D/A conversion and amplification at speech-processing section 13, after which it is transmitted from speaker 131 as received voice audio. On the other hand, the transmitted voice audio of the user is collected by microphone 132 and converted into a transmission signal, after which it is undergoes amplification and A/D conversion at speech-processing section 13 and is converted into digital data. Then, after undergoing modulation and frequency conversion, it is transmitted as a radio signal from wireless communication section 12 through antenna 121.


Display 4 includes, for example, a liquid crystal display and a liquid crystal drive circuit and displays various information, user-interactive screens (e.g., a function selection screen), or the like according to instructions from controller 11. Operating section 15 includes, for example, a numeric keypad from “0” to “9,” an on-hook key and an off-hook key, and keys for moving a cursor on the display screen and delivers signals according to user operations to controller 11. Based on these signals, controller 11 determines the details of the instructions provided through the user operations and executes processes according to the results of the determination.


Short-range wireless communication section 17 includes an antenna and a radio control circuit (both not shown) and implements wireless communication with any mobile phone handset 10 (proximate mobile phone) that is present within the short-range wireless area. Any communication system may be used for short-range wireless communication section 17, and examples include systems compatible with the Bluetooth (registered trademark) specification and general-purpose infrared data communication systems. When these systems are used, the short-range wireless area covers a range with a radius of up to around 10 m. Controller 11 uses short-range wireless communication section 17 to detect the presence of proximate mobile phones.


Memory 16 is, for example, an EEPROM (Electrically Erasable and Programmable Read Only Memory) or a flash memory. Memory 16 stores programs that describe procedures for processes executed by controller 11. For example, it stores application programs for implementing various functions. Application programs are programs used for implementing various functions, such as exchanging business cards, adjusting ringtone volume, exchanging information, and playing games as described above. Moreover, memory 16 also stores a display control program for listing these functions names and allowing the user to select any of these functions. Moreover, memory 16 stores identification information assigned to mobile phone handset 10. This identification information may be a suitable predefined character string or a telephone number or E-mail address, but in the present exemplary embodiment, a predefined character string is used.


Moreover, memory 16 stores telephone registration table 161, table of environment definitions 162, and table of functions 163. The contents of these tables will now be described.



FIG. 3 is a diagram showing one example of the content described in telephone registration table 161. As shown in FIG. 3, telephone registration table 161 matches and describes identification information of mobile phone handset 10 with the date when the identification information was described in telephone registration table 161 (date of registration). The user of a mobile phone handset 10 that stores telephone registration table 161 and the user of a mobile phone handset 10 corresponding to identification information registered in telephone registration table 161 are mutual acquaintances. These users each operate their respective mobile phone handsets 10, exchange the identification information of their respective mobile phone handsets 10 using a wireless communication function of short-range wireless communication section 17, and register one another's identification information in telephone registration table 161. Moreover, one of the users may ask for the identification information of the other user's mobile phone handset 10 and manually input the information using operation section 15 to register it in telephone registration table 161.



FIG. 4 is a diagram showing one example of the content of table of environment definitions 162 and FIG. 5 is a diagram showing one example of the content of table of function 163. Table of environment definitions 162 defines the environment around mobile phone handset 10 based on the number of proximate mobile phones and the registration status of nearby telephones. As shown in FIG. 4, in table of environment definitions 162, the detected details of proximate mobile phones are matched with environment classes assigned to each environment. Table of functions 163 defines the environments in which each function name should be prioritized and displayed. As shown in FIG. 5, in table of functions 163, function identification information (function names in this exemplary embodiment) assigned to each function is matched with an environment class.


First, the details of table of environment definitions 162 will be described.


The environments defined in this table include the following five types.


The first environment (environment class “1”) is one in which there are no proximate mobile phones. In other words, the user of mobile phone handset 10 is in a location that is apart from other people and is therefore isolated. Therefore, as shown in FIG. 5, functions for handling private information, such as e-mail or a scheduler, are matched with environment class “1.”


The second environment (environment class “2”) is one in which there are 1-5 unregistered proximate mobile phones. In other words, there are relatively few (1-5) strangers near the user of mobile phone handset 10. In this type of environment, strangers often exchange business cards. Moreover, this type of environment is also encountered when waiting before a cash register to make a payment at a store. Therefore, as shown in FIG. 5, business-card-exchange functions and small-payment functions are matched with environment class “2.”


The third environment (environment class “3”) is one in which there are 6 or more unregistered proximate mobile phones or 16 or more registered proximate mobile phones. In other words, there is a relatively high number (6 or more) of strangers near the user of mobile phone handset 10 or a relatively large number (16 or more) of acquaintances near the user of mobile phone handset 10. When the user is in such an environment, it may be assumed that the user is in a public space. Therefore, as shown in FIG. 5, ringtone volume adjustment functions for lowering the ringtone volume of mobile phone handset 10 as a matter of public courtesy and silent-mode functions for switching to a silent mode in which the user is notified of received calls through vibrations are matched with environment class “3.”


The fourth environment (environment class “4”) is one in which there are 1-5 registered nearby telephones. In other words, there are only relatively few (1-5) acquaintances near the user of mobile phone handset 10. This type of environment is often encountered during company meetings or when music and other content are being exchanged, for example. Therefore, as shown in FIG. 5, information synchronization functions for exchanging business information and synchronizing information, as well as content exchange functions for exchanging content, are matched with environment class “4.”


Finally, the fifth environment (environment class “5”) is one in which there is a relatively high number (6-15) of acquaintances near the user of mobile phone handset 10. This type of environment is often encountered when, for example, friends are playing competitive games or a large group is playing a role-playing game. Therefore, as shown in FIG. 5, functions for competitive games and multiplayer games are matched with environment class “5.”


Controller 11 judges the environment surrounding the device based on table of environment definitions 162, specifies the function names to be prioritized and displayed in that environment, and displays those function names on display 14. However, the surrounding environment may not always be specified by a single environment, and the environment judged based on the presence and number of proximate mobile phones may simultaneously match multiple environments defined in table of environment definitions 162. For example, in a hypothetical case there may be, for example, three registered proximate mobile phones and one unregistered proximate mobile phones at a location in which mobile phone handset 10 is present. In this case, based on table of environment definitions 162, which is shown in FIG. 4, the environment matches both environment class “2” and environment class “4.”


In preparation for such cases in which multiple environments are simultaneously applicable, it is determined in advance which of the functions matched with each environment class are prioritized and displayed. Specifically, the display control program stored in memory 16 describes weighting information assigned to each environment. For example, the environment classes may be ranked as follows in descending order of weighting: environment class 2>environment class 3>environment class 4>environment class 1 (the inequality signs indicate the relative weightings). In this case, when environment class “2” and environment class “4” compete as described above, the environment of environment class “2” is prioritized over the environment of environment class “4”. By specifying the order of precedence of different environments, the display sequence of the function names may be specified according to the order of precedence. In other words, in table of functions 163, the function names matched with environment class “2” are prioritized and displayed followed by the function names matched with environment class “4,” and the remaining functions are displayed in a given sequence or at random. Environments of environment class “0” do not compete with the other environments and are therefore not subject to weighting.


Next, a software configuration of mobile phone handset 10 will be described with reference to FIG. 6.


At the manufacturing stage of mobile phone handset 10, several programs are preliminarily written into the ROM of controller 11. These programs will hereinafter be referred to as “preinstalled programs.” These preinstalled programs include, for example, multitask operating systems (hereinafter, “multitask OS”), Java (registered trademark) platforms, and native functions. As a general description of these programs, a multitask OS is an operating system that supports various functions for implementing pseudo-parallel execution of multiple tasks in a TSS (Time-Sharing System), such as allocating virtual memory space. A Java platform is a group of programs described according to a CDC (Connected Device Configuration), which is a configuration for implementing Java execution environment 214 (described below) in a mobile device loaded with a multitask OS. A native function is a program that implements basic services of mobile phone handset 10, such as telephone conversations.


In relation to the ROM configuration described above, memory 16 has a Java function storage area that stores Java functions. The Java functions include physical programs describing procedures for processes in Java execution environments, JAR (Java Archive) files combining image files and audio files used when the physical programs are executed, and ADF (Application Descriptor Files) describing the installation and start-up and various attributes of the JAR files. The Java functions are stored in Internet server devices prepared by a content provider or the telecommunications carrier of mobile phone network 100 and downloaded from the server devices into mobile phone handset 10 in response to a request from mobile phone handset 10.


As shown in FIG. 6, in mobile phone handset 10, calling application program 212 and Java execution environment 241 are implemented on OS 211. Calling application program 212 is a native program preliminarily stored in memory 16 and implements functions such as accepting and making calls and exchanging audio signals. Java execution environment 214 is implemented by the Java platform stored in the ROM. Java execution environment 214 includes class library 217, JVM (Java Virtual Machine) 218, and JAM (Java Application Manager) 219. Class library 217 combines groups of program modules (classes) with specific functions into a single file. JVM 218 is a Java execution environment that has been optimized for the CDC described above and includes functions for reading and executing byte codes provided as Java functions. This JVM is also referred to as a CVM (Compact Virtual Machine). JAM 219 includes functions for managing the downloading, installation, and start-up and shutdown of Java functions. This JAM is also referred to as an AMS (Application Management System).


Moreover, memory 16 is also configured with first storage 215 and second storage 216. First storage 215 is a storage area for Java functions (Jar files and ADF) downloaded under the management of JAM 219. Second storage 216 is an area for storing data generated when a Java function is executed after the function is shut down, and a separate storage area is allocated for each installed Java function. The data in the storage area allocated to a given Java function is rewritable only when the Java function is being executed, and other Java functions cannot be rewritten at that time.


Display control program 213 is a program related to displaying the function selection screen described above. Display control program 213 is a Java function program implemented in Java execution environment 214. Application program group 214 includes programs for implementing the various functions described above. Application program group 214 includes the Java function programs implemented in Java execution environment 214 as well as the preinstalled programs stored in the ROM. Examples of the latter preinstalled application programs include programs for implementing E-mail functions, ringtone volume adjustment functions, and silent-mode functions. The multitask OS is configured so that display control program 213 and application program group 214 may be executed in parallel.


This concludes the description of the configuration of the present exemplary embodiment.


(2-2) Operations

Next, operations of the present exemplary embodiment will be described.


First, the process by which controller 11 judges the environment will be described with reference to the flowcharts of FIG. 7 and FIG. 10. Short-range wireless communication sections 17 of mobile phone handsets 10-1, 10-2, 10-3 to 10-n in FIG. 1 regularly transmit a polling signal to their respective short-range wireless areas. The polling signal includes identification information of mobile phone handset 10 of the source. For example, the polling signals transmitted by short-range wireless communication sections 17 of mobile phone handsets 10-1, 10-3 are received by short-range wireless communication section 17 of mobile phone handset 10-2. Then, short-range wireless communication section 17 of mobile phone handset 10-2 extracts the identification information included in the received polling signals and provides the information to controller 11. In FIG. 7, once the identification information included in the polling signals is provided from short-range wireless communication section 17, controller 11 determines that proximate mobile phones have been detected (step S1: Yes).


Controller 11 generates a judgment table describing information related to the current environment on the RAM. FIG. 8 is a diagram showing one example of the judgment table. Controller 11 describes the identification information provided from short-range wireless communication section 17 in the judgment table (step S2), describes the registration status of the proximate mobile phones to which the identification information has been assigned in the judgment table (step S3), and updates the number of proximate mobile phones in the judgment table (step S4). For example, if controller 11 receives the identification information “5stjiji84554” from short-range wireless communication section 17, in step S2, it adds a new record in the judgment table and describes the identification information “5stjiji84554” in the record. As shown in FIG. 3, the identification information “5stjiji84554” is identification information that has already been described in telephone registration table 161. Consequently, in step S3, controller 11 describes the identification information “5stjiji84554” as “Registered” in the corresponding “Registration status” field. Then, as shown in FIG. 8, because the number of registered proximate mobile phones was “2” in the judgment table before the identification information “5stjiji84554” was described, in step S4, controller 11 increases the number of registered proximate mobile phones by 1 and updates the number to “3.” As a result, the content of the judgment table corresponds to the example shown in FIG. 9.


Returning to FIG. 7, controller 11 judges the current environment based on the content of the judgment table and the content of the table of environment definitions 162 (step S5). When the content of the judgment table includes 3 registered proximate mobile phones and 1 unregistered nearby telephone as shown in FIG. 9, controller 11 judges that the environment corresponds to environment class “2” and environment class “4” according to the table of environment definitions 162 of FIG. 4. Here, as described above, environment class “2” is prioritized over environment class “4,” and therefore, controller 11 defines the environment of environment class “2” as the highest priority environment and the environment of environment class “4” as the environment to be prioritized next. By thus defining environment class “2” and environment class “4” as the highest priority environment and the environment to be prioritized next, respectively, and storing them in a given area of the RAM, controller 11 updates the current environment (step S6). Then, the processing performed by controller 11 returns to step S1.


The above processes of steps S2-S6 are executed each time a nearby telephone is detected, and the environment around mobile phone handset 10 is judged each time.



FIG. 7 illustrates operations performed when a nearby telephone enters the short-range wireless area, but FIG. 10 is a flowchart showing the processes performed when a nearby telephone exits the short-range wireless area.


If, for example, mobile phone handset 10-1 exits short-range wireless area RA of mobile phone handset 10-2 in FIG. 1, short-range wireless communication section 17 of mobile phone handset 10-2 becomes unable to receive the polling signals that were being regularly received from mobile phone handset 10-1. When the period of time during which controller 11 is no longer able to receive the polling signals that were being received from mobile phone handset 10-1 exceeds a predetermined period of time (step S11: Yes), controller 11 removes the identification information included in the polling signals from the judgment table and also removes the registration status from the judgment table (step S12). Then, controller 11 updates the number of proximate mobile phones in the judgment table (step S13). In other words, controller 11 subtracts 1 from the “number of registered proximate mobile phones ” or the “number of unregistered proximate mobile phones ” in the judgment table exemplified in FIG. 8. Then, based on the content of the judgment table and the content of the table of environment definitions 162, controller 11 judges the current environment (step S14). By storing the environment class of the judged environment in a given area on the RAM, controller 11 updates the current environment (step S15). At this time, if multiple environments are competing, an order of preference may be specified according to the weighting of each environment. The processing performed by controller 11 returns to step S11.


The above processes of step S12-S15 are executed each time a nearby telephone exits the short-range wireless area (i.e., each time a proximate mobile phones moves out of range), and the environment around mobile phone handset 10 is assessed each time.


Next, processes of controller 11 for displaying a function selection screen and implementing any of the functions will be described with reference to the flowchart of FIG. 11.


In FIG. 11, when controller 11 detects that operating section 15 has received some type of operation (step S21: Yes), it determines what type of process has been instructed by the operation (step S22). If the instruction is to display a function selection screen (step S22: display function selection screen), controller 11 specifies the environment class of the current environment stored in the RAM (step S23). Next, controller 11 refers to table of functions 163, specifies the function names corresponding to the specified environment class, and determines the display sequence of the function names (step S24).


Then, controller 11 displays the function selection screen, which lists the function names according to the display sequence (step S25). For example, when environment class “2” and environment class “4” are the highest priority environment and the environment to be prioritized next, respectively, controller 11 displays a function selection screen similar to the one shown in FIG. 12. When the user selects a desired function name, controller 11 accepts the operation (step S21: Yes). Then, when controller 11 determines that a certain function name has been selected by the operation (step S22: function selection), it executes an application program to implement the function and implements the selected function (step S26). In step S22, if it is determined that the operation provides an instruction for a different process (step S22: other), controller 11 executes a corresponding process (step S27).


According to the exemplary embodiment described above, the environment around a mobile phone handset is judged according to a number of proximate mobile phones and the registration status of those proximate mobile phones, and the display sequence of the function names on the function selection screen is changed according to the environment. As a result, by determining the environment of other mobile phones in the vicinity of the first mobile phone handset, functions that are highly likely to be selected by the user may be displayed at a position requiring fewer operations for selection. Consequently, the number of operations required of a user for selecting any of multiple functions may be reduced.


(3) Modified Examples

The present invention is not limited to the exemplary embodiment described above, and modifications such as the following may be made. In addition, the details of each of the following modified examples may be combined when appropriate.


(3-1) Mode of the Communication Terminal

The exemplary embodiment has been described based on an example using a mobile phone handset with calling functions as a mobile terminal. However, the mobile terminal is not limited to this, and the present invention may be applied to a mobile terminal without calling functions, such as a PDA (Personal Digital Assistant) or mobile computer with functions for wireless data communication.


(3-2) Mode of the Algorithm for Judging the Environment

The details of the algorithm for judging the environment are not limited to those described in the exemplary embodiment, and the content of table of environment definitions 162 or table of functions 163 may be different from the content shown in FIGS. 4 and 5. For example, for table of environment definitions 162, which is shown in FIG. 4, the number of proximate mobile phones has been described as an example of criterion for judging the environment, but this number may be changed or adjusted to an appropriate value corresponding to the lifestyles or lifestyle patterns of individual users or their patterns of use of functions. For example, the user may use operating section 15 to set the number of proximate mobile phones corresponding to each environment class to any appropriate number.


Moreover, for table of functions 163, which is shown in FIG. 5, the function names have been matched with the environment classes, but these matching relationships may be set by the user using operating section 15. For example, if the user refers to a function selection screen on which function names have been arranged in a given sequence and performs operations to change the display positions (display sequence), controller 11, which should already have judged the surrounding environment at that point in time, matches the environment class of the environment with the function names provided with a higher priority in the display sequence by the user and describes them in table of functions 163. Subsequently, controller 11 determines the display sequence of the function names according to the content of table of functions 163 and displays a function selection screen on which the function names have been arranged according to the display sequence. In this way, mobile phone handset 10 learns the appropriate relationships of correspondence between the functions and the environments based on the history of changes made to the display positions by the user.


Moreover, in preparation for situations in which multiple environments compete to be defined as the surrounding environment, weighting information of each of the environments is described in the display control program. The weighting for each environment may also be configured or changed by the user using operating section 15, for example.


Moreover, the content to be written into table of environment definitions 162 or table of functions 163 may be described in an application program describing procedures for controller 11 to implement a function. This is particularly useful when downloading a new application program onto mobile phone handset 10 through a network or installing an application program read out from a storage medium onto mobile phone handset 10. The following is a detailed description.


In this example, two users are exchanging data between their respective mobile phone handsets using a short-range wireless function to play a tennis game. In a given area of the application program for implementing the tennis game function, the status of proximate mobile phones is described as “1 registered nearby telephone” and the application name is described as “Tennis game.” Controller 11 of mobile phone handset 10 uses wireless communication section 12 to download (obtain) the application program and stores it in memory 16. Next, controller 11 reads out the status of proximate mobile phones of “1 registered nearby telephone” from the given area of the application program and writes this into a new record on table of environment definitions 162. Then, controller 11 issues a new environment class “6”, matches environment class “6” with the status of proximate mobile phones of “1 registered nearby telephone,” and writes this into table of environment definitions 162. Furthermore, controller 11 creates a new record in table of functions 163, writes “Tennis game” as a function name, and writes “6” as the corresponding environment class. Once table of environment definitions 162 and table of functions 163 have been updated in this manner, controller 11 may continue operating as described in the above exemplary embodiment.


Moreover, the given area of the application program may describe only the environment class and the application name. In this case, the environment class described in the application program is one of “1” to “5” described in table of environment definitions 162 of mobile phone handset 10. Controller 11 of mobile phone handset 10, after obtaining the application program and storing it in memory 16, may then create a new record in the column for the environment class on table of functions 163 and write the application name as the function name.


In this way, the content of table of environment definitions 162 or table of functions 163 may be updated according to the intentions of the provider of the application program.


(3-3) Determination of Display Sequence According to Instructions from Other Mobile Phone Handsets


When function identification information assigned to a function is transmitted from a nearby telephone detected by mobile phone handset 10, mobile phone handset 10 may receive the function identification information and set a display sequence in which the function name to which the received function identification information has been assigned is arranged at a position requiring fewer operations of the user for selecting the function. The following is a detailed description.


In this example, five users are exchanging business cards. When the five users enter a single room, their respective mobile phone handsets 10 each detect one another as proximate mobile phones. Then, for example, two of the five users operate their own mobile phone handsets 10 to display the function selection screen and select a business-card-exchange function on the screen. At this time, controller 11 of mobile phone handsets 10 of these two users transmits function identification information assigned to the business-card-exchange function using short-range wireless communication section 17. As a result, short-range wireless communication section 17 of mobile phone handsets 10 of the remaining three users receives the function identification information assigned to the business-card-exchange function from the first two mobile phone handsets. Controller 11 of the three mobile phone handsets 10, upon receiving identical function identification information from two or more nearby telephones, determines a display sequence in which the business-card-exchange function name to which the received function identification information is assigned is arranged at a position requiring fewer operations of the user for selecting the function compared to other function names. Then, controller 11 displays the function names using the display sequence.


In this example, “2 handsets” was set as the threshold value, wherein identical function identification information was received from proximate mobile phones of the threshold value or more, but the threshold value may be determined arbitrarily. For example, a different threshold value may be determined for each function.


In this way, mobile phone handset 10 may arrange the function name specified by function identification information transmitted from mobile phone handsets present within a given distance at a position requiring fewer operations of the user for selecting the function.


(3-4) Environment Judgment for Different Users

For example, when lending out a mobile phone handset for business use to a company employee, there are cases in which a single mobile phone handset is shared by multiple users. In this case, it may be preferable for telephone registration table 161, table of environment definitions 162, table of functions 163, and weighting information for each environment to be set differently for each user. This is because each user has different interpersonal relationships and lifestyles and uses the mobile phone handset differently. In this case, memory 16 stores telephone registration table 161, table of environment definitions 162, and table of functions 163 for each user. Moreover, weighting information for each environment is also stored in memory 16 for each user. Mobile phone handset 10 includes a user identification unit that identifies the user of the handset through, for example, password verification or fingerprint authentication. Controller 11 identifies the user through the user specification unit and uses telephone registration 161, table of environment definitions 162, table of functions 163, and weighting information for each environment corresponding to the user to perform operations similar to those of the exemplary embodiment.


(3-5) Environment Judgment for Different Regions

The judgment criteria for the environment surrounding the user may also change depending on the region (area) the user is in. For example, when the user is in a specified area, such as the office or at home, even if there are a high number of unregistered proximate mobile phones, it may not be necessary to define the environment as a public space (environment class 2). On the other hand, when the user is in an unspecified area outside the office or home, even if there is only 1 unregistered proximate mobile phone, the user may be in a public space. In other words, the content of table of environment definitions 162 and table of functions 163 may be changed according to the area that mobile phone handset 10 is in.


Specifically, in addition to including a positioning unit using GPS (Global Positioning System) technology or the like in mobile phone handset 10, position information of specified areas, such as the office and home, is stored in memory 16. When the user issues an instruction to display the function selection screen, controller 11 compares the position read by the positioning unit and the positions stored in memory 16 and judges whether mobile phone handset 10 (i.e., the user) is in a specified area, such as the office or home, or in an unspecified area. If the user is in a specified area, such as the office or home, controller 11 may determine the display sequence of the function names on the function selection screen based on the content of table of environment definitions 162 and table of functions 163 that have been prepared for each area. On the other hand, if the user is in an unspecified area, controller 11 may determine the display sequence of the function names on the function selection screen based on the content of table of environment definitions 162 and table of functions 163 prepared for the unspecified area.


(3-6) Mode of the Detection Unit

The unit for detecting proximate mobile phones is not limited to units using short-range wireless communication. For example, a positioning unit using GPS technology may read the position of each mobile phone handset 10 and detect the presence of proximate mobile phones based on the positional relationships. Alternatively, various sensors, such as magnetic sensors, optical sensors, infrared sensors, and temperature sensors, may be used to detect proximate mobile phones (or the users carrying a proximate mobile phone).


(3-7) Mode of the Program

The display control program executed by controller 11 may be stored and provided on a recording medium, such as a magnetic tape, a magnetic disk, a flexible disk, an optical recording medium, a magneto-optical medium, a CD (Compact Disk), a DVD (Digital Versatile Disk), or a RAM. Moreover, it may also be downloaded onto mobile phone handset 10 through a network, such as a mobile phone network or the Internet.

Claims
  • 1. A mobile terminal comprising: a display control unit that displays, on a display, a function selection screen on which a plurality of function names are arranged in accordance with a given sequence;a selection operation unit that accepts an operation for selecting any of the function names arranged on the function selection screen;an implementation unit that implements the function with the name selected through the operation accepted by the selection operation unit;a detection unit that detects another mobile terminal present within a given distance from a position of the mobile terminal; anda determination unit that determines different sequences to be complied with by the display control unit for a case in which other mobile terminals are detected by the detection unit, and for a case in which other mobile terminals are not detected by the detection unit.
  • 2. The mobile terminal according to claim 1, wherein: the detection unit determines a number of other mobile terminals present within the given distance from the position of the mobile terminal; andthe determination unit determines the sequence depending on the number of other mobile terminals determined by the detection unit.
  • 3. The mobile terminal according to claim 1, further comprising an identification information memory that stores identification information assigned to the detected other mobile terminals, other than the mobile terminal, wherein: the detection unit determines the identification information assigned to the detected other mobile terminals present within the given distance from the position of the mobile terminal; andthe determination unit determines the sequence differently for a case in which the identification information determined by the detection unit matches the information stored in the identification information memory, and a case in which the identification information determined by the detection unit does not match the information stored in the identification information memory.
  • 4. The mobile terminal according to claim 1, wherein: the determination unit further comprises:an environment definition memory that stores information detected by the detection unit and an environment class assigned to each of a plurality of environments defined in advance as environments of the mobile terminal;a function memory that stores function identification information assigned to each of the functions and the environment classes;an environment specification unit that specifies the environment class that is associated with the information detected by the detection unit and stored in the environment definition memory; anda function specification unit that specifies function identification information that is associated with the environment class specified by the environment specification unit and stored in the function memory, anddetermines the sequence to arrange the function name assigned to the function identification information specified by the function specification unit at a position where the function name is selectable by use of fewer operation selection steps than are required to be used for selection of other of the function names.
  • 5. The mobile terminal according to claim 4, wherein, if the environment specification unit specifies a plurality of environment classes, the determination unit specifies an order of precedence for each of the plurality of environment classes according to a weighting assigned to each of the plurality of environment classes, and determines the sequence according to the specified order of precedence.
  • 6. The mobile terminal according to claim 1, further comprising: a modification operation unit that accepts operations for modifying the sequence determined by the determination unit; anda modified-content memory that stores content modified through the operations accepted by the modification operation unit, whereinthe determination unit determines the sequence according to the content stored in the modified-content memory.
  • 7. The mobile terminal according to claim 4, further comprising: an acquisition unit that acquires a program describing steps for implementing the function using the implementation unit along with the content stored in the environment definition memory or the function memory; andan update unit that updates the content stored in the environment definition memory or the function memory according to the content described in the program acquired by the acquisition unit.
  • 8. The mobile terminal according to claim 1, further comprising a reception unit that, when function identification information assigned to the function is transmitted from another mobile terminal detected by the detection unit, receives the function identification information, wherein the determination unit determines the sequence to arrange the function name to which the function identification information received by the reception unit has been assigned at a position where the function name is selectable by use of fewer operation selection steps than are required to be used for selection of other of the function names.
  • 9. The mobile terminal according to claim 1, further comprising a user identification unit that identifies a user using the mobile terminal, wherein the determination unit determines the sequence for the user identified by the user identification unit.
  • 10. The mobile terminal according to claim 1, further comprising an area specification unit that specifies an area in which the mobile terminal is located, wherein the determination unit determines the sequence for each area specified by the area specification unit.
  • 11. A program causing a computer to function as: a display control unit that displays a function selection screen on which a plurality of function names are arranged in accordance with a given sequence, and that is used to select any of a plurality of function names;a detection unit that detects another mobile terminal present within a given distance from the position of the computer; anda determination unit that determines different sequences to be complied with by the display control unit for a case in which other mobile terminals are detected by the detection unit, and for a case in which other mobile terminals are not detected by the detection unit.
Priority Claims (1)
Number Date Country Kind
2007-192409 Jul 2007 JP national
PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/JP2008/063270 7/24/2008 WO 00 6/4/2010