US20090013276A1 - Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering - Google Patents
Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering Download PDFInfo
- Publication number
- US20090013276A1 US20090013276A1 US12/233,880 US23388008A US2009013276A1 US 20090013276 A1 US20090013276 A1 US 20090013276A1 US 23388008 A US23388008 A US 23388008A US 2009013276 A1 US2009013276 A1 US 2009013276A1
- Authority
- US
- United States
- Prior art keywords
- discovered
- filter
- filters
- objects
- code configured
- 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.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W8/00—Network data management
- H04W8/005—Discovery of network devices, e.g. terminals
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/51—Discovery or management thereof, e.g. service location protocol [SLP] or web services
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M1/00—Substation equipment, e.g. for use by subscribers
- H04M1/72—Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
- H04M1/724—User interfaces specially adapted for cordless or mobile telephones
- H04M1/72403—User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
- H04M1/72409—User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories
- H04M1/72412—User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories using two-way short-range wireless interfaces
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W92/00—Interfaces specially adapted for wireless communication networks
- H04W92/16—Interfaces between hierarchically similar devices
- H04W92/18—Interfaces between hierarchically similar devices between terminal devices
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Databases & Information Systems (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
The present invention provides a method, apparatus and computer instructions for scaling a user interface adaptively to an object discovery or display system with policy driven filtering. A number of filters are defined by the user in an initial setup. The filter includes a target number of discovered objects and a metric for filtering discovered objects. Once the initial setup is complete, the present invention automatically triggers or deactivates the filters and dynamically applies one or more filters based on the number of discovered objects and rules defined by the user. Resulting discovered objects are displayed in the user interface to the user.
Description
- 1. Technical Field
- The present invention relates generally to an improved data processing system. In particular, the present invention provides a method and apparatus for displaying discovered objects to the user. Still more particularly, the present invention provides a method, apparatus and computer instructions for adaptively scaling a user interface to an object discovery/display system with policy-driven filtering.
- 2. Description of Related Art
- With the increasing use of mobile devices, such as cellular phones, pagers, laptop computers, personal digital assistants (PDAs), communications between users of these devices also increase. Communications are made to exchange information, such as, for example, emails, instant messages, images, and files. Conventionally, when a user wants to communicate with one another through the use of a mobile device, the user first tries to connect to a peer discovery system, which discovers all mobile devices that are within the range of a certain bandwidth. Common wireless communication protocols, such as bluetooth or wireless fidelity (Wi-Fi), are generally used for connecting these mobile devices. Bluetooth is a standard protocol, available from bluetooth SIG, for short-range radio links between devices. Bluetooth replaces links currently supported by many cables. Wireless fidelity (Wi-Fi) is a networking technology that uses IEEE 802.11a or IEEE 802.11b standard to provide fast, secure and reliable wireless connectivity. A peer-to-peer environment may use the above technologies to share information between devices or share an Internet connection.
- When the mobile device is connected to the peer discovery system, available peers, meaning other mobile device users, are displayed in a user interface to allow the user to interact with the user's peers. However, as the number of available peers or discovered objects becomes large, it becomes difficult and unwieldy for the user to look through the large number of available peers for one with which to interact. This difficulty is magnified by the small displays that are available on most mobile devices, such as mobile phones and PDAs. Thus the issue of how to filter discovered objects in order to adequately display to the user becomes a problem.
- Currently, existing object discovery or display systems often filter discovered objects using built-in rules, which the user has no control over. In addition, existing systems follow a pre-set order of filtering, where one rule follows another immediately without considering the dynamic nature of discovered objects.
- Therefore, it would be advantageous to have an improved method, apparatus and computer instructions for scaling a user interface to an object discovery or display system with policy-driven filtering that allows users to define filtering rules and dynamically applies filters to discovered objects as appropriate.
- The present invention provides a method, apparatus and computer instructions for scaling a user interface to an object discovery or display system with policy-driven filtering. The mechanism of the present invention allows users to define rules of filtering or policies, in order to filter the number of discovered objects to be displayed in a user interface.
- The present invention allows a user to first define a number of filters to apply on discovered objects in an initial setup. The user then defines a target number of discovered objects and a metric for each filter.
- Once the initial setup is complete, the present invention dynamically triggers or deactivates defined filters based on the number of discovered objects. If a filter is triggered, the present invention filters discovered objects according to the metric defined for the filter. The present invention then displays filtered discovered objects in the user interface. In the absence of a filter in the initial setup, none of the discovered objects are filtered.
- The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
-
FIG. 1 is a pictorial representation of a peer-to-peer environment in which the present invention may be implemented in accordance with a preferred embodiment of the present invention; -
FIG. 2 is a block diagram of a data processing system in which the present invention may be implemented; -
FIG. 3 is an exemplary block diagram of a wireless communication device in which the present invention may be implemented in accordance with a preferred embodiment of the present invention; -
FIG. 4 is a diagram illustrating components used for scaling adaptively to an object discover or display system with policy-driven filtering in accordance with a preferred embodiment of the present invention; -
FIG. 5 is a diagram illustrating an example of adaptive scaling a user interface to an object discovery or display system with policy-driven filtering using the present invention in accordance with a preferred embodiment of the present invention; -
FIG. 6 is a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object is discovered in accordance with the present invention; and -
FIG. 7 is a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object disappears in accordance with the present invention. - As is known in the art, object discovery is typically performed in a peer-to-peer environment in which an object discovery or display system exists on at least two computing devices that communicate with one another by way of a wireless communication protocol, such as bluetooth or Wi-Fi. Therefore, in order to provide a context in which the present invention may be implemented, the following description of a peer-to-peer environment is provided.
- With reference now to the figures,
FIG. 1 depicts a pictorial representation of a peer-to-peer environment in which the present invention may be implemented. Peer-to-peer environment 100 is an exemplary environment in which the present invention may be implemented. - In the depicted example, peer-to-
peer environment 100 includesclients peer environment 100 also may include additional clients, and other devices not shown. Each client in peer-to-peer environment 100 may be connected to the Internet withnetwork 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational and other computer systems that route data and messages. - In the depicted example, peer-to-
peer environment 100 also includescommunication links client 108 connects to the peer discovery system, which resides onclient 108, the peer discovery system tries to connect with other clients, such asclient communication links Communications links communication links client communication link 124, which is also implemented as a bluetooth connection. - Typically, a connection is made when the peer discovery system of a first client, such as
client 110, broadcasts a User Datagram Protocol (UDP) message. This message is received by available clients over a local subnet. For example, the peer discovery system of a second client, such asclient 112, receives the broadcast message and decides whether to make a connection withclient 110. Ifclient 112 acceptsclient 110 after filtering is performed, a connection is made. In the prior art,client 112 filters discovered objects, such asclient 110, based on a set of established rules in the system and a set of pre-set orders to apply those rules. However, using the innovative feature of the present invention, the user ofclient 112 may create user defined rules to filter the clients to be displayed in the user interface. These rules may be based on the target number of objects and metrics, such as common interests, and type of hardware used. - Once a connection is made using communication links, such as
communication links available clients client 108 in a user interface as discovered objects. - In addition to a wireless implementation, peer-to-
peer environment 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).FIG. 1 is intended as an example, and not as an architectural limitation for the present invention. - Referring to
FIG. 2 , a block diagram of a computing device that may be implemented as a client, such asclients FIG. 1 , is shown in which the present invention may be implemented.Computing device 200 is an example of a computer, such as a laptop computer or a workstation, in which code or instructions implementing the present invention may be located.Computing device 200 employs a peripheral component interconnect (PCI) local bus architecture. Although the depicted example employs a PCI bus, other bus architectures such as Accelerated Graphics Port (AGP) and Industry Standard Architecture (ISA) may be used.Processor 202 andmain memory 204 are connected to PCIlocal bus 206 throughPCI bridge 208.PCI bridge 208 also may include an integrated memory controller and cache memory forprocessor 202. Additional connections to PCIlocal bus 206 may be made through direct component interconnection or through add-in boards. In the depicted example, local area network (LAN)adapter 210, small computer system interface SCSIhost bus adapter 212, andexpansion bus interface 214 are connected to PCIlocal bus 206 by direct component connection. To contrast,audio adapter 216,graphics adapter 218, and audio/video adapter 219 are connected to PCIlocal bus 206 by add-in boards inserted into expansion slots.Expansion bus interface 214 provides a connection for a keyboard andmouse adapter 220,modem 222, andadditional memory 224. SCSIhost bus adapter 212 provides a connection forhard disk drive 226,tape drive 228, and CD-ROM drive 230. Typical PCI local bus implementations will support three or four PCI expansion slots or add-in connectors. - An operating system runs on
processor 202 and is used to coordinate and provide control of various components withincomputing device 200 inFIG. 2 . The operating system may be a commercially available operating system such as Windows XP, which is available from Microsoft Corporation. Instructions for the operating system and applications or programs are located on storage devices, such ashard disk drive 226, and may be loaded intomain memory 204 for execution byprocessor 202. - Those of ordinary skill in the art will appreciate that the hardware depicted in
FIG. 2 may vary depending upon the implementation. Other internal hardware or peripheral devices, such as flash read-only memory (ROM), equivalent nonvolatile memory, or optical disk drives and the like, may be used in addition to or in place of the hardware depicted inFIG. 2 . Also, the processes of the present invention may be applied to a multiprocessor data processing system. - For example,
computing device 200, if optionally configured as a network computer, may not include SCSIhost bus adapter 212,hard disk drive 226,tape drive 228, and CD-ROM 230. In that case, the computer, to be properly called a client computer, includes some kind of network communication interface, such asLAN adapter 210,modem 222, or the like. As another example,data processing system 200 may be a stand-alone system configured to be bootable without relying on some type of network communication interface, whether or not computingsystem 200 comprises some type of network communications interface. - The depicted example in
FIG. 2 and above-described examples are not meant to imply architectural limitations.Computing system 200 also may include any type of computing device that is capable of running an instant messaging client application without departing from the spirit and scope of the present invention. Examples of such computing devices include, but is not limited to, personal digital assistants (PDAs), laptop computers, network computers, wireless telephones, pager devices, and the like. - With reference to
FIG. 3 , an exemplary block diagram of a wireless communication device in which the present invention may be implemented is depicted in accordance with a preferred embodiment of the present invention.Wireless communication device 300 includes aprocessor 302 for controlling operation of the communication device and amemory 304. Theprocessor 302 may be a general-purpose microprocessor operating under the control of instructions stored in memory, such asmemory 304, or device-specific circuitry for controlling the operation of the telephone device.Processor 302 is connected bysystem bus 306 totransmitter 308,receiver 310,keypad 314,display 316, andaudio processor 318.Keypad 314 may be a keypad and/or buttons.Display 316 may be any type of display device including a liquid crystal display (LCD) or other known displays, such as a cathode ray tube or active matrix display. -
Transmitter 308 andreceiver 310 are coupled to a telephone signal bycouple 324 to provide full duplex communication. The telephone signal may be provided by a telephone line (not shown) in a land-based telephone or an antenna, such as for a wireless telephone.Audio processing circuit 318 provides basic analog audio outputs tospeaker 320 and accepts analog audio inputs frommicrophone 322. Received signals are demodulated and decoded byreceiver 310.Transmitter 308 encodes and modulates signals passed to it byprocessor 302 oraudio processor 318. The output of the transmitter is amplified bypower amplifier 312 to control the power level at which the signal is transmitted. -
Processor 302 oraudio processor 318 may detect audible call status information and call status codes received byreceiver 310.Memory 304 may include a lookup table associating call status information or call status codes with visual call status information, such as text messages.Processor 302 detects or receives a call status code and displays an appropriate call status message ondisplay 316. Those of ordinary skill in the art will appreciate that the hardware depicted inFIG. 3 may vary. - The present invention provides a method, apparatus and computer instructions for scaling a user interface adaptively to an object discovery or display system with policy driven filtering. The present invention allows a user to define an initial setup, which includes a number of filters for filtering discovered objects. For each defined filter, the user specifies a target number of discovered objects to be displayed and a metric for determining a peer's desirability. Examples of metric include common interests, prior interaction, and number of prior connections. An example filter may be used to show only objects with common interest in sports if the number of discovered objects is less than 20 or to show only objects that a user interacted before if the number of discovered objects is less than 30. Once the initial setup is complete, the present invention may dynamically determine which and how many discovered objects are to be displayed in the user interface.
- In a preferred embodiment, upon detection of a new discovered object, the present invention checks the total number of discovered objects against the user-defined filters to see if one or more filters are triggered based on the target number of objects. A filter is triggered if the number of discovered objects is greater than or equal to the target number of discovered objects defined in the filter. In a similar manner, upon detection of a disappeared object, which decreases the number of discovered objects, the filter is deactivated if the number of discovered objects is less than the target number of discovered objects defined in the filter.
- If at least one filter is triggered, the present invention applies the metric, if defined in the initial setup, for the given filter to each discovered object, in order to determine whether the discovered object should be displayed. If the object does not meet the requirements of the metric, the object is ignored. If the object meets the requirements of the metric, the present invention continues with the next triggered filter to determine whether the object meets the metric of the next triggered filter. Once the object meets metric requirements of all triggered filters, the object is displayed. Thus, each discovered object is checked against the metric of each triggered filter before being displayed.
- In addition, the present invention provides a mechanism that dynamically triggers or deactivates filters as the number of discovered object changes. For example, a user may specify a basic filter with a target number of 10, a second filter with a target number of 20 and a third filter with a target number of 30. If the initial number of discovered objects detected is 15, the basic filter is triggered, since 15 is greater than 10. When the number of discovered objects detected is increased to 21, both the first and the second filter are triggered since 21 is greater than 20 and 10. When the number of discovered objects is again increased to 35, all three filters are then triggered since 35 is greater than 30, 20 and 10. When the number of discovered objects is reduced to 27, the first and second filters are triggered since 27 is greater than 20 and 10, however, the third filter is deactivated since 27 is less than 30.
- Turning now to
FIG. 4 , a diagram illustrating components used for scaling adaptively to an object discover or display system with policy-driven filtering is depicted in accordance with a preferred embodiment of the present invention. As depicted inFIG. 4 , the present invention may be implemented in a peer-to-peer environment, such as peer-to-peer environment 300 inFIG. 3 . Peer-to-peer environment 400 includespeer discovery systems Peer discovery system 402 may be implemented onclient 401,peer discovery system 404 may be implemented onclient 403, and peerdiscovery system 406 may be implemented onclient 405.Client client FIG. 1 .Client user interfaces - In one example implementation, when
client 401 wants to join peer-to-peer environment 400 to interact with other clients,client 401 connects to peerdiscovery system 402 through the user ofuser interface 407.Peer discovery system 402 sends a broadcast message over a local subnet usingcommunication link client 401, which provides thereceiver client 401's identity. - Upon receiving the message from
client 401,peer discovery system 404 ofclient 403adaptively filters client 401 based on the user-defined initial setup. If no filter is defined in the initial setup,peer discovery system 404 ofclient 403 displaysclient 401 in the user interface. If the current number of objects discovered byclient 403 is greater than or equal to the target number specified in one or more filters in the initial setup, at least one filter is triggered. If at least one filter is triggered,peer discovery system 404 then determines whetherclient 401 meets the metric specified for each filter triggered. Ifclient 401 meets the metric specified for each filter triggered,peer discovery system 404 ofclient 403 displaysclient 401 inuser interface 409. Ifclient 401 does not meet the metric specified for each filter triggered,client 401 is ignored bypeer discovery system 404. Similarly,peer discovery system 406 ofclient 405adaptively filters client 401 when the message is received throughcommunication link 412. - Turning now to
FIG. 5 , a diagram illustrating an example of adaptive scaling a user interface to an object discovery or display system with policy-driven filtering using the present invention is depicted in accordance with a preferred embodiment of the present invention. As depicted inFIG. 5 , in this example implementation, peer-to-peer environment 500 includes seven clients:client A 502,client B 504,client C 506,client D 508,client E 510,client F 512, andclient G 514. - In this example,
client A 502 is the client of interest andinitial setup 520 is the initial setup ofclient A 502. The user ofclient A 502 definesinitial setup 520, which includes two filters: filter 1 522 andfilter 2 524.Filter 1 522 includes a target number of 5 and a metric of interest in sports.Filter 2 524 includes a target number of 2 and also a metric of interest in sports. - When
client A 502 receives broadcast messages from all other clients, peer discovery system running onclient A 502 detects that there are six nearby clients:client B 504,C 506,D 508,E 510,F 512 andG 514. Peer discovery system first clears aCurrentFilterArray 523, which is a data structure used to store filters triggered by the number of discovered clients. - Based on
initial setup 520 forclient A 502, peer discovery system ofclient A 502 checks the number of discovered clients against the target number specified in defined filters ininitial setup 520. In this example, since the number of discovered clients is 6, which is greater than the target number of 5 defined infilter 1 522 and the target number of 2 defined infilter 2 524, bothfilter 1 526 andfilter 2 527 are triggered and added toCurrentFilterArray 523. - Once the filters are added, peer discovery system of
client A 502 clearsCurrentDisplayedObjectArray 525, which is a data structure used to store discovered objects that meet metric requirements of filters inCurrentFilterArray 523. Next, for each filters stored inCurrentFilterArray 523, peer discovery system ofclient A 502 determines whether each discovered object meets the metric defined in the filter. In this example,client B 504 meets metric specified infilter 1 526, which has a common interest in sports. Thus,client B 528 is added toCurrentlyDisplayedObjectArray 525. - Peer discovery system of
client A 502 then determines whetherclient B 504 meets metric specified for the next filter inCurrentFilterArray 523, which isfilter 2 527.Client B 504 also meets metric offilter 2 527, butclient B 504 is already stored inCurrentlyDisplayedObjectArray 525 and therefore is not added. Peer discovery system ofclient A 502 repeats the same process forclient C 506,D 508,E 510,F 512, andG 514. In this example,client C 529 andclient D 530 also meet metrics specified forfilter 1 526 andfilter 2 527, and are therefore added toCurrentlyDisplayedObjectArray 525. - Once peer discovery system of
client A 502 completes determination of metric requirements for filters stored inCurrentFilterArray 523, peer discovery system refreshes the user interface ofclient A 502 and displays all clients stored inCurrentlyDisplayedObjectArray 525 to the user ofclient A 502. - As clients dynamically join and leave peer-to-
peer environment 500, a different peer-to-peer environment, peer-to-peer environment 531, emerged. Peer-to-peer environment 531 includes only four of the seven previous clients:client A 532,client B 534,client D 536, andclient F 538.Client A 502 maintainsinitial setup 520 as specified by the user. - In this example, when
client A 532 receives broadcast messages from all other clients, peer discovery system ofclient A 532 detects only three nearby clients:client B 534,D 536, andF 538. Peer discovery system first clearsCurrentFilterArray 523 and checks the number of discovered clients against the target number specified in filters ofinitial setup 520. In this example, since the number of discovered clients is 3, which is greater than the target number of 2 defined infilter 2 524, but less than the target number of 5 defined infilter 1 522, only filter 2 541 is added toCurrentFilterArray 540. Thus, the present invention allows peer discovery system ofclient A 532 to trigger or deactivate filters dynamically as the number of discovered object changes. - Once
filter 2 is added toCurrentFilterArray 540, peer discovery system ofclient A 532 clearsCurrentDisplayedObjectArray 542 and determines whether each discovered object meets the metric defined in thefilter 2 541. In this example,client B 534 andclient D 536 meet metric specified infilter 2 541, since both have common interests in sports. Thus, client B 543 and client D 544 are added toCurrentlyDisplayedObjectArray 542. - Once peer discovery system of
client A 532 completes determination of metric requirements forfilter 2 541 stored inCurrentFilterArray 540, peer discovery system refreshes the user interface ofclient A 532 and displays all clients stored inCurrentlyDisplayedObjectArray 542 to the user ofclient A 532. - Thus, using the innovative features of the present invention, the user of a client, such as
client A 502, may define one or more filters to filter discovered objects when detected by the client. The user may also define metric requirements for each discovered object for each filter, so that the peer discovery system may adaptively display relevant clients in the user interface. In addition, the present invention dynamically triggers and deactivates the filter as the number of discovered objects changes. - With reference to
FIG. 6 , a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object is discovered is depicted in accordance with the present invention. The process illustrated inFIG. 6 may be implemented in a data processing system such ascomputing device 200 inFIG. 2 orwireless communications device 300 inFIG. 3 . - As depicted in
FIG. 6 , in this example implementation, the process begins when a new object is discovered by a client (step 602). An object, such asclient 110 inFIG. 1 , may be discovered when the peer discovery system of a client sends a broadcast message to nearby clients. Next, the receiving client clears its current filter array (step 604), which is a data structure used to store filters triggered by the number of discovered clients. - Then, the peer discovery system of the client checks the initial setup and makes a determination as to whether at least one or more filters are defined (step 606). If no filter is defined in the initial setup, the process continues to step 620. If at least one or more filters are defined in the initial setup, the peer discovery system obtains the target number of discovered objects from the filter stored in the initial setup (step 608). Next, a determination is made by the peer discovery system as to whether the number of discovered objects is greater than or equal to the target number obtained in step 608 (step 610). If the number of discovered objects is greater than or equal to the target number, the filter is triggered (step 612). If the number of discovered objects is less than the target number obtained in
step 608, the process continues to step 616. - Continuing from
step 612, if at least one filter is triggered, the peer discovery system makes a determination as to whether any additional filter is defined in the initial setup (step 616). If additional filter is defined in the initial setup, the peer discovery system goes to the next filter defined in the initial setup (step 618) and the process continues to step 608. If no additional filter is defined in the initial setup, the peer discovery system clears the currently displayed object array (step 620) and obtains each discovered object (step 622). The currently displayed object array is a data structure used to store discovered objects that meet metric requirements of filters in the current filter array. - Once a discovered object is obtained, a determination is made by the peer discovery system as to whether at least one or more filters are stored in the current filter array (step 624). A filter is stored in the current filter array at
step 614 when a filter is triggered atstep 612. If no filter is stored in the current filter array, the processor continues to step 630. If at least one filter is stored in the current filter array, the peer discovery system obtains the metric defined from the filter stored in the current filter array (step 626) and a determination is made as to whether the discovered object satisfies the metric defined in the filter (step 628). Examples of metric include number of previous interactions, type of hardware, and interest in sports. If the discovered object does not satisfy the metric, the process terminates thereafter. If the discovered object satisfies the metric, the peer discovery system adds the object to the currently displayed object array (step 630) and refreshes the display of the user interface to show all objects stored in currently displayed object array (step 632). - Once the display of the user interface is refreshed, a determination is made by the peer discovery system as to whether additional filters are stored in current filter array (step 634). If additional filters are stored in the current filter array, the peer discovery system goes to the next filter in the current filter array (step 636) and obtains the metric defined for the next filter (step 626). If no additional filters are stored in the current filter array, the process terminating thereafter.
- For a more efficient operation, instead of clearing the currently displayed object filter array, the peer discovery system may check the newly discovered object, after satisfying the metric, against the array to determine whether it is currently stored. If it is not stored, the discovered object may be added to the array.
- Turning now to
FIG. 7 , a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object disappears is depicted in accordance with the present invention. The process illustrated inFIG. 7 may be implemented in a data processing system such ascomputing device 200 inFIG. 2 orwireless communications device 300 inFIG. 3 . - As depicted in
FIG. 7 , in this example implementation, the process begins when an object disappears (step 702). An object disappears, for example, when a client leaves a peer-to-peer environment. The object disappearance causes a decrease in the number of discovered objects. - Next, a determination is made by the peer discovery system as to whether at least one or more filters are stored in the current filter array (step 704). If at least one or more filters are stored in the current filter array, the peer discovery system obtains the target number of the discovered objects from the filter stored in the current filter array (step 706). If no filter is stored in the current filter array, the process continues to step 716. Continuing from
step 706, a determination is made by the peer discovery system as to whether the number of discovered objects is greater than or equal to the target number obtained instep 706. If the number of discovered objects is greater than or equal to the target number, the process continues to step 712. If the number of discovered objects is less than the target number, the filter is removed from the current filter array (step 710). The removal of filter deactivates the filter. - A determination is then made as to whether any additional filter is stored in the current filter array (step 712). If additional filter is stored in the current filter array, the peer discovery system goes to the next filter in the current filter array and obtains the target number of discovered objects defined in the next filter (step 706). If no additional filter is stored in the current filter array, the peer discovery system clears the currently displayed object array (step 716), which is a data structure used to store discovered objects that meet metric requirements of filters in the current filter array. Then, the peer discovery system obtains each discovered object (step 718).
- When a discovered object is obtained, a determination is made as to whether at least one or more filters are stored in the current filter array (step 720). If at least one or more filters are stored in the current filter array, the peer discovery system obtains the metric defined in the filter (step 722). If no filter is stored in the current filter array, the process continues to step 726. Once the metric is obtained, a determination is made as to whether the discovered object obtained in
step 718 satisfies the metric (step 724). If the discovered object does not satisfy the metric, the process terminating thereafter. If the discovered object satisfies the metric, the discovered object is added to the currently displayed object array (step 726) and the display of all objects in the currently displayed object array is refreshed in the user interface (step 728). - After the display is refreshed, a determination is made as to whether additional filters are stored in the current filter array (step 730). If additional filters are stored in the current filter array, the peer discovery system goes to the next filter in the current filter array (step 732) and obtains the metric in the next filter (step 722). If no additional filters are stored in the current filter array, the process terminating thereafter.
- For a more efficient operation, instead of clearing the currently displayed object array, the peer discovery system may obtain each object stored in the currently displayed object array and determines whether the object should be displayed.
- Thus, the present invention provides advantages over current peer-to-peer systems by adaptively filtering and displaying relevant and manageable information to the user without restricting the users' interaction to their social networks. In addition, the present invention dynamically adjusts display of discovered objects based on the number of discovered objects and automatically triggers or deactivates one or more filters as appropriate. By allowing the user to define initial setup, the present invention gives users control over what information is to be displayed.
- It is important to note that while the present invention has been described in the context of a fully functioning data processing system, those of ordinary skill in the art will appreciate that the processes of the present invention are capable of being distributed in the form of a computer readable medium of instructions and a variety of forms and that the present invention applies equally regardless of the particular type of signal bearing media actually used to carry out the distribution. Examples of computer readable media include recordable-type media such a floppy disc, a hard disk drive, a RAM, and CD-ROMs and transmission-type media such as digital and analog communications links.
- The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Claims (19)
1-18. (canceled)
19. A computer program product, comprising:
a computer recordable-type medium storing computer usable program code for adaptively scaling a user interface to an object discovery system, the computer program product comprising:
computer usable program code configured for receiving a user input to define a plurality of filters to filter discovered objects in an initial setup of a data processing system;
computer usable program code configured for detecting a change in a number of the discovered objects;
in response to detecting the change in the number of the discovered objects, computer usable program code configured for automatically triggering at least one filter of the defined plurality of filters, wherein the triggered at least one filter defines a target number of discovered objects to be displayed in the user interface and a metric for determining a desirability of displaying a discovered object in the user interface;
in response to automatically triggering the at least one filter of the defined plurality of filters, computer usable program code configured for filtering at least one discovered object of the discovered objects by the triggered at least one filter to form at least one filtered discovered object; and
computer usable program code configured for displaying the at least one filtered discovered object in the user interface.
20. The computer program product of claim 19 , wherein the metric includes one of a number of previous interactions, a common interest or a type of hardware used.
21. The computer program product of claim 19 , wherein the initial setup is defined by a user of the data processing system.
22. The computer program product of claim 19 , wherein the computer usable program code configured for automatically triggering at least one filter of the defined plurality of filters comprises:
computer usable program code configured for comparing the target number of discovered objects with the number of discovered objects.
23. The computer program product of claim 19 , wherein the computer usable program code configured for filtering at least one discovered object of the discovered objects comprises:
computer usable program code configured for determining whether the at least one discovered object satisfies the metric of the triggered at least one filter.
24. The computer program product of claim 19 , wherein the computer usable program code configured for detecting a change in a number of the discovered objects comprises:
computer usable program code configured for receiving a message from at least one discovered object over at least one communication link.
25. The computer program product of claim 24 , wherein the communication link includes a bluetooth or Wi-Fi connection.
26. The computer program product of claim 19 , wherein the computer usable program code configured for automatically triggering at least one filter of the defined plurality of filters comprises:
computer usable program code configured for automatically deactivating the at least one filter of the defined plurality of filters in response to detecting the change.
27. The computer program product of claim 26 , wherein the computer usable program code configured for automatically deactivating the at least one filter of the defined plurality of filters comprises:
computer usable program, code configured for comparing a target number of discovered objects with the number of discovered objects.
28. A data processing system for adaptively scaling a user interface to an object discovery system, comprising:
a bus system;
a storage device connected to the bus system, wherein the storage device includes a set of instructions; and
a processing unit connected to the bus system, wherein the processing unit executes the set of instructions to receive a user input to define a plurality of filters to filter discovered objects in an initial setup of the data processing system, detect a change in a number of the discovered objects, in response to detecting the change in the number of the discovered objects, automatically trigger at least one filter of the defined plurality of filters, wherein the triggered at least one filter defines a target number of discovered objects to be displayed in the user interface and a metric for determining a desirability of displaying a discovered object in the user interface, in response to automatically triggering the at least one filter of the defined plurality of filters, filter at least one discovered object of the discovered objects by the triggered at least one filter to form at least one filtered discovered object, and display the at least one filtered discovered object in the user interface.
29. The data processing system of claim 28 , wherein the metric includes one of a number of previous interactions, a common interest or a type of hardware used.
30. The data processing system of claim 28 , wherein the initial setup is defined by a user of the data processing system.
31. The data processing system of claim 28 , wherein the processing unit executing the set of instructions to automatically trigger at least one filter of the defined plurality of filters comprises:
the processing unit executing the set of instructions to compare the target number of discovered objects with the number of discovered objects.
32. The data processing system of claim 28 , wherein the processing unit executing the set of instructions to filter at least one discovered object of the discovered objects comprises:
the processing unit executing the set of instructions to determine whether the at least one discovered object satisfies the metric of the triggered at least one filter.
33. The data processing system of claim 28 , wherein the processing unit executing the set of instructions to detect a change in a number of the discovered objects comprises:
the processing unit executing the set of instructions to receive a message from at least one discovered object over at least one communication link.
34. The data processing system of claim 33 , wherein the communication link includes a bluetooth or Wi-Fi connection.
35. The data processing system of claim 28 , wherein the processing unit executing the set of instructions to automatically trigger at least one filter of the defined plurality of filters comprises:
the processing unit executing the set of instructions to automatically deactivate the at least one filter of the defined plurality of filters in response to detecting the change.
36. The data processing system of claim 35 , wherein the processing unit executing the set of instructions to automatically deactivate the at least one filter of the defined plurality of filters comprises:
the processing unit executing the set of instructions to compare a target number of discovered objects with the number of discovered objects.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/233,880 US20090013276A1 (en) | 2004-01-05 | 2008-09-19 | Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/753,185 US7472185B2 (en) | 2004-01-05 | 2004-01-05 | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering |
US12/233,880 US20090013276A1 (en) | 2004-01-05 | 2008-09-19 | Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/753,185 Continuation US7472185B2 (en) | 2004-01-05 | 2004-01-05 | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering |
Publications (1)
Publication Number | Publication Date |
---|---|
US20090013276A1 true US20090013276A1 (en) | 2009-01-08 |
Family
ID=34749356
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/753,185 Expired - Fee Related US7472185B2 (en) | 2004-01-05 | 2004-01-05 | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering |
US12/233,880 Abandoned US20090013276A1 (en) | 2004-01-05 | 2008-09-19 | Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering |
US12/236,247 Expired - Fee Related US7774452B2 (en) | 2004-01-05 | 2008-09-23 | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/753,185 Expired - Fee Related US7472185B2 (en) | 2004-01-05 | 2004-01-05 | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/236,247 Expired - Fee Related US7774452B2 (en) | 2004-01-05 | 2008-09-23 | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering |
Country Status (1)
Country | Link |
---|---|
US (3) | US7472185B2 (en) |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4682052B2 (en) * | 2006-02-10 | 2011-05-11 | キヤノン株式会社 | COMMUNICATION DEVICE, COMMUNICATION METHOD, COMMUNICATION DEVICE CONTROL METHOD, AND COMMUNICATION SYSTEM |
JP4886463B2 (en) | 2006-10-20 | 2012-02-29 | キヤノン株式会社 | Communication parameter setting method, communication apparatus, and management apparatus for managing communication parameters |
US8082507B2 (en) * | 2007-06-12 | 2011-12-20 | Microsoft Corporation | Scalable user interface |
JP5122201B2 (en) * | 2007-07-24 | 2013-01-16 | 株式会社エヌ・ティ・ティ・ドコモ | Mobile terminal and program |
US8199671B2 (en) * | 2008-06-09 | 2012-06-12 | Hewlett-Packard Development Company, L.P. | Throttling network traffic generated by a network discovery tool during a discovery scan |
JP4803306B1 (en) * | 2010-04-07 | 2011-10-26 | ソニー株式会社 | Battery pack and battery pack manufacturing method |
EP2586223B1 (en) * | 2010-06-23 | 2020-05-27 | Qualcomm Incorporated | Event-triggered peer discovery |
US8605875B2 (en) | 2011-02-24 | 2013-12-10 | International Business Machines Corporation | Dynamic call management and display |
US8861005B2 (en) * | 2012-09-28 | 2014-10-14 | Interactive Memories, Inc. | Methods for real time discovery, selection, and engagement of most economically feasible printing service vendors among multiple known vendors |
US10567566B2 (en) * | 2012-10-16 | 2020-02-18 | Nokia Technologies Oy | Method and apparatus for providing mechanism to control unattended notifications at a device |
Citations (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5787252A (en) * | 1995-11-01 | 1998-07-28 | Hewlett-Packard Company | Filtering system and method for high performance network management map |
US6020876A (en) * | 1997-04-14 | 2000-02-01 | Immersion Corporation | Force feedback interface with selective disturbance filter |
US6233686B1 (en) * | 1997-01-17 | 2001-05-15 | At & T Corp. | System and method for providing peer level access control on a network |
US6389534B1 (en) * | 1997-06-30 | 2002-05-14 | Taher Elgamal | Cryptographic policy filters and policy control method and apparatus |
US20020062375A1 (en) * | 2000-11-22 | 2002-05-23 | Dan Teodosiu | Locator and tracking service for peer to peer resources |
US20020073075A1 (en) * | 2000-12-07 | 2002-06-13 | Ibm Corporation | Method and system for augmenting web-indexed search engine results with peer-to-peer search results |
US6421716B1 (en) * | 1998-09-30 | 2002-07-16 | Xerox Corporation | System for generating context-sensitive hierarchically ordered document service menus |
US20030067912A1 (en) * | 1999-07-02 | 2003-04-10 | Andrew Mead | Directory services caching for network peer to peer service locator |
US20040162871A1 (en) * | 2003-02-13 | 2004-08-19 | Pabla Kuldipsingh A. | Infrastructure for accessing a peer-to-peer network environment |
US7127493B1 (en) * | 1998-08-20 | 2006-10-24 | Gautier Taylor S | Optimizing server delivery of content by selective inclusion of optional data based on optimization criteria |
US7206841B2 (en) * | 2001-01-22 | 2007-04-17 | Sun Microsystems, Inc. | Rendezvous for locating peer-to-peer resources |
US7209949B2 (en) * | 1998-05-29 | 2007-04-24 | Research In Motion Limited | System and method for synchronizing information between a host system and a mobile data communication device |
US7272407B2 (en) * | 2003-02-18 | 2007-09-18 | Hewlett-Packard Development Company, L.P. | Display on wireless mobile device |
US7386588B2 (en) * | 1998-05-29 | 2008-06-10 | Research In Motion Limited | System and method for pushing information from a host system to a mobile data communication device |
US20110092221A1 (en) * | 2009-10-16 | 2011-04-21 | Michael Zubas | Devices and Methods for Selectively Filtering Message Content |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6829615B2 (en) * | 2000-02-25 | 2004-12-07 | International Business Machines Corporation | Object type relationship graphical user interface |
US7519575B1 (en) * | 2001-08-31 | 2009-04-14 | Novell, Inc. | Method and apparatus for presenting, searching, and viewing directories |
US7627552B2 (en) * | 2003-03-27 | 2009-12-01 | Microsoft Corporation | System and method for filtering and organizing items based on common elements |
US7409644B2 (en) * | 2003-05-16 | 2008-08-05 | Microsoft Corporation | File system shell |
-
2004
- 2004-01-05 US US10/753,185 patent/US7472185B2/en not_active Expired - Fee Related
-
2008
- 2008-09-19 US US12/233,880 patent/US20090013276A1/en not_active Abandoned
- 2008-09-23 US US12/236,247 patent/US7774452B2/en not_active Expired - Fee Related
Patent Citations (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5787252A (en) * | 1995-11-01 | 1998-07-28 | Hewlett-Packard Company | Filtering system and method for high performance network management map |
US6233686B1 (en) * | 1997-01-17 | 2001-05-15 | At & T Corp. | System and method for providing peer level access control on a network |
US6020876A (en) * | 1997-04-14 | 2000-02-01 | Immersion Corporation | Force feedback interface with selective disturbance filter |
US6389534B1 (en) * | 1997-06-30 | 2002-05-14 | Taher Elgamal | Cryptographic policy filters and policy control method and apparatus |
US7386588B2 (en) * | 1998-05-29 | 2008-06-10 | Research In Motion Limited | System and method for pushing information from a host system to a mobile data communication device |
US7209949B2 (en) * | 1998-05-29 | 2007-04-24 | Research In Motion Limited | System and method for synchronizing information between a host system and a mobile data communication device |
US7127493B1 (en) * | 1998-08-20 | 2006-10-24 | Gautier Taylor S | Optimizing server delivery of content by selective inclusion of optional data based on optimization criteria |
US6421716B1 (en) * | 1998-09-30 | 2002-07-16 | Xerox Corporation | System for generating context-sensitive hierarchically ordered document service menus |
US20030067912A1 (en) * | 1999-07-02 | 2003-04-10 | Andrew Mead | Directory services caching for network peer to peer service locator |
US20020062375A1 (en) * | 2000-11-22 | 2002-05-23 | Dan Teodosiu | Locator and tracking service for peer to peer resources |
US20020073075A1 (en) * | 2000-12-07 | 2002-06-13 | Ibm Corporation | Method and system for augmenting web-indexed search engine results with peer-to-peer search results |
US7206841B2 (en) * | 2001-01-22 | 2007-04-17 | Sun Microsystems, Inc. | Rendezvous for locating peer-to-peer resources |
US20040162871A1 (en) * | 2003-02-13 | 2004-08-19 | Pabla Kuldipsingh A. | Infrastructure for accessing a peer-to-peer network environment |
US7272407B2 (en) * | 2003-02-18 | 2007-09-18 | Hewlett-Packard Development Company, L.P. | Display on wireless mobile device |
US20110092221A1 (en) * | 2009-10-16 | 2011-04-21 | Michael Zubas | Devices and Methods for Selectively Filtering Message Content |
Also Published As
Publication number | Publication date |
---|---|
US20050160261A1 (en) | 2005-07-21 |
US7472185B2 (en) | 2008-12-30 |
US20090019144A1 (en) | 2009-01-15 |
US7774452B2 (en) | 2010-08-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7774452B2 (en) | Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering | |
US8898260B2 (en) | Automatic multimedia upload for publishing data and multimedia content | |
US20180227322A1 (en) | Near real-time detection of suspicious outbound traffic | |
CN105847168B (en) | data transmission method, network server, user terminal and system | |
WO2023155074A1 (en) | Communication method and apparatus, electronic device, and storage medium | |
JP4546801B2 (en) | Method for providing synchronization notification to client device | |
US20070242061A1 (en) | Mobile auxiliary display model | |
US20170289838A1 (en) | Dynamic selection of tcp congestion control for improved performances | |
US8737923B2 (en) | System and method for reducing radio frequency interference between a wireless communication device and a speaker | |
CN112272118A (en) | Network repairing method, device, storage medium and electronic equipment | |
CN106155468B (en) | Alarm display method and terminal | |
CN114071544B (en) | Network testing method and device and electronic equipment | |
US20150056967A1 (en) | System and method for community based mobile device profiling | |
CN106992893A (en) | The management method and device of router | |
US20140219260A1 (en) | Method and apparatus for communicating between mobile devices | |
CN110489657B (en) | Information filtering method and device, terminal equipment and storage medium | |
GB2514093A (en) | Receiving a communication event | |
CN113839859B (en) | Message notification method and related device | |
JP2006254446A (en) | Detection of supported network frequency to enable successful connection to wireless networks | |
US20050085187A1 (en) | Wireless user note server apparatus, methods and computer program products and wireless terminals for use therewith | |
US20110221607A1 (en) | Dynamic Device Adaptation Based on Proximity to Other Devices | |
JP3759137B2 (en) | Wireless communication apparatus and impersonation terminal detection method | |
US20030023720A1 (en) | System and method for remotely monitoring modem status | |
US20240040043A1 (en) | Acoustic feedback management in real-time audio communication | |
JP6094276B2 (en) | Information processing apparatus, method, and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE |