The present disclosure relates generally mobile device software applications.
In recent years the focus of consumer-oriented software developers has shifted away from personal computers towards software applications (“apps”) for smartphone and tablet computers. While there are other, less-popular operating systems for smartphone and tablet computers, the most prevalent operating system for such devices is the Android™ operating system produced by Google Inc. of Mountain View Calif.
Android and certain other operating systems allow third party developers to develop apps that run on top of them. Moreover these operating systems and associated app stores allow device users to quickly search for, download, and install apps. The ease with which apps can be developed and put on sale through app stores has created an incentive for large numbers of software developers to create a myriad of apps. The number of apps is so large and growing at such a rate that it would be a daunting task to review the ergonomics of the Graphical User Interface (GUI) of each app.
This creates opportunities for assisting in checking the ergonomics of the GUIs of a large number of apps (e.g., >100,000) deployed on a large number of devices (e.g., >100,000,000) and thereby aiding in the improvement of the GUIs. Furthermore such a system might alert app store managers and/or app developers to apps that may have a problematic GUI.
The accompanying figures, where like reference numerals refer to identical or functionally similar elements throughout the separate views and which together with the detailed description below are incorporated in and form part of the specification, serve to further illustrate various embodiments and to explain various principles and advantages all in accordance with the present disclosure.
Skilled artisans will appreciate that elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale. For example, the dimensions of some of the elements in the figures may be exaggerated relative to other elements to help to improve understanding of embodiments of the present disclosure.
Before describing in detail embodiments that are in accordance with the present disclosure, it should be observed that the embodiments reside primarily in combinations of method steps and apparatus components related to erroneous user interaction and GUI adaptation. Accordingly, the apparatus components and method steps have been represented where appropriate by conventional symbols in the drawings, showing only those specific details that are pertinent to understanding the embodiments of the present disclosure so as not to obscure the disclosure with details that will be readily apparent to those of ordinary skill in the art having the benefit of the description herein.
The devices 106 can take the form of smartphones or tablet computers or other electronic devices with GUIs such as internet-connected televisions, networked game consoles, and various types of electronic accessories with GUIs. The devices 106 may number in the hundreds of millions and there may be millions of devices running a given app. As described below in more detail, the devices 106 collect certain data indicative of problems with GUI operability or ergonomics and such data is communicated through the one or more networks 104 to the servers 102 which aggregate and process the data in order to discern such problems with GUI operability or ergonomics.
The processor 304 controls the overall operation of the device 106. The processor 304 uses the workspace memory 314 to execute both operating system and software application programs stored in the program memory 312. Programs that may be stored in the program memory 312 and executed by the processor 304 according to certain embodiments are described below with reference to
The back light driver 316 is coupled to a back light 340 which is optically coupled to the display 338. The touch sensor 336 in combination with the display 338 constitutes one embodiment of the touch screen 208 as shown in
While the electronic device shown in
The firmware layer 404 includes an input manager 412, a windows manager 414, a view hierarchy 416, a touch input event controller 418, and an accessibility manager 420. The input manager 412, the view hierarchy 416, and the accessibility manager 420 are standard components of Android™. The touch driver 410 is communicatively coupled to an input manager 412 in the firmware layer 404. The input manager 412 is communicatively coupled to a windows manager 414, and the windows manager 414 is communicatively coupled to the view hierarchy 416 and the touch input event controller 418.
The accessibility manager 420 is communicatively coupled to a touch recorder app 422 in the app layer 406. The touch recorder app 422 includes a touch recorder accessibility service 424, an event filter 426, an event parser compactor 428, memory 430, back up files 432, debug and statistics data 434, and a checkin publisher module 436. The accessibility manager 420 may be used to implement elements of
The checkin publisher module 436 is communicatively coupled to a checkin server 438 of the server 408. The app layer 406 also includes a settings app 440 and guru apps 442. The guru apps 442 are applications which call the TouchRecorderApp APIs or service to get data including raw data, summary data, or key statistic data. Based on this information, a guru app 442 may adjust a user interface element's size or position in real time as will be described later in conjunction with
A portion of an OS (e.g., Android™) main screen app launcher 614 is shown in the middle of
A system navigation bar 620 is shown at the bottom of
In designing a GUI, there is a conflict between the desire to fit more buttons (or other active regions) and the issue that, if the active regions are too small and close together, user accuracy in selecting a desired active region declines. For a given GUI, certain active regions, depending, at least, on their size, location, and appearance may be inaccurately actuated when compared against a user's intention. Which active regions are problematic may not be discernable a priori to a software designer. Erroneous interactions can take the form of a user touching a passive region rather than active region. Erroneous interactions can also take the form of a user touching an unintended active region.
In block 703, the device 106 processor 304 receives screen touch information from a touch sensor controller 310. In block 704, a processor of the device initializers a counter to zero. Multiple counters may be implemented with each instance of the counter applying to particular app, a particular GUI screen within the app, and a particular erroneous interaction pattern type which can be detected in subsequent blocks 706-714.
When the processor 304 resolves the touch sensor controller 310 data to a valid touch on a passive region, the flow notifies decision block 706 that a passive region has been touched. See
When the processor 304 determines that the outcome of decision block 710 is positive meaning that the active region was touched within the predetermined time limit after the passive region was touched, the process 700 proceeds to decision block 712 the outcome of which depends on whether active region that was touched by the user is adjacent to the passive region that was touched by the user. If the outcome of decision block 712 is positive, the process 700 proceeds to decision block 714, which means that an erroneous interaction is considered to have been detected. It is inferred in this case that the user intended to press the active region that was pressed second, but inadvertently touched the adjacent passive region first.
Next in block 716 the counter that was initialized in block 704 is incremented by one. Thereafter decision block 718 tests if the counter has reached a preprogrammed threshold (e.g., 10 times). If the outcome of decision block 718 is negative, the process 700 loops back to block 706 and continues executing as previously described. If, on the other hand, decision block 718 determines that the counter has reached the threshold, then the process 700 proceeds to block 720 where the processor 304 indicates that erroneous interaction pattern 1 has been detected. The device's touch recorder app 422 may transmit this indicator to a server 102 via a wired or wireless transceiver 302 along with the context information from block 702. If the outcome of any of blocks 706, 708, 710, or 712 is negative, then the process 700 loops back to block 706 and continues executing as previously described.
By testing to see if the erroneous interaction is repeated a threshold number of times, the process 700 is discerning a persistent erroneous user interaction, as opposed to a chance or infrequent error. Alternatively, each time block 714 is reached, an indication of a single instance of an erroneous user interaction and the context information can be sent to the servers 102, and the servers 102 can then perform further data analysis to determine if the same erroneous interaction is being repeated in a population of devices with similar context information. As another alternative, the context information from block 702 and touch information from block 703 can be transmitted to a server 102 and the analysis and erroneous interaction pattern detection of block 705 can be determined by the server 102. Blocks 706, 708, 710, 712, 714, 716 together form a first erroneous interaction detector 705.
Block 806 is a decision block the outcome of which depends on whether the processor 304 receives touch sensor controller 310 information indicating the user has touched a first action region. See
If the outcome of decision block 812 is positive, then the process 800 proceeds to block 814, which means that the processor has detected an AR touch correction sequence. Next, in block 816, the processor 304 increments the counter that was initialized in block 804 by one. Following block 816, decision block 818 tests if the counter has reached a preprogrammed limit (e.g., 10). If so, block 820 outputs an indication that an erroneous interaction pattern has been detected. The context information collected in block 802 may be output along with the indication in block 820. The indication may be output to another program running on the device, such as a Guru App 442, or may sent through the one or more networks 104 to the servers 102.
According to certain embodiments, each device 106 executes the process 800 and the indications generated in block 820 are sent through the network(s) 104 to the servers 102. Alternatively, time stamped touch coordinate data, from block 803, and the context data collected in block 802 can be sent by each device 106 to the servers, and the remainder of the process 800 can be executed by the servers 102. When the outcome of any of decision blocks 806, 808, 810, 812, and 818 is negative, the process 800 loops back the start of block 806. Blocks 806, 808, 810, 812, 814 and 816 form a second erroneous interaction detector 805.
In block 1208 information about the erroneous interactions (e.g., information collected in blocks 702, 802 and the output of blocks 720, 820) is communicated through the one or more networks 104 to at least one server 102. In block 1210 at least one server (e.g., of the network of servers 102) aggregates information about erroneous interactions that was received in block 1208 from multiple devices in the population of devices. Through the process of aggregation, erroneous interactions that are prevalent (e.g., to a statistically significant degree) throughout the population of devices (in contrast to a case where it occurs with just one or an insignificant fraction of users) can be identified and made visible to the software developers that produced the app. In block 1212, based on the aggregated information, the first software code that was generated in block 1202 is modified to obtain a second version of software code that addresses the problem of erroneous interaction identified in blocks 1206-1210. The modified second software code can include a change in the size, position color and/or shape of a GUI element.
The ergonomics of users' interaction with the GUI of a particular app may be dependent on the size of the device 102 and its touch screen 208. For example, if the device is a smartphone with a 4.5″ (11.4 cm) screen, the user may grasp the device with the fingers of one hand and operate the touch screen 208 with the thumb of the same hand—all GUI elements possibly being within reach of the thumb. On the other hand, if the device is a tablet with a 10″ (25.4 cm) screen, the user may set the device on a table or hold the device with both hands and operate the touch screen 208 with fingers of two hands. According to certain embodiments a subprogram, such as BigQuery Service 504, running on the network of servers 102 accesses stored information as to the screen size for each model of electronic device and is able to associate the indications of erroneous interaction (e.g., the information output in block 520, 620) with a particular screen size based on the model information included in the context information collected in block 502, 602 (which is also sent to the network of servers 102). The subprogram can then separately aggregate the erroneous interaction information received from a population of devices for each screen size or range of screen size. For example screen sizes can be separated into a number of ranges, e.g., less than 4″ (10.2 cm); 4″-5″ (10.2 cm-15.2 cm); 5″-6″ (12.7 cm-15.2 cm) and so on. Then the program can output information on erroneous interactions for each screen size or screen size range using elements 506, 512, 514, and 520. Subsequently developers can develop and deploy separate new versions of their app for each of multiple screen sizes with each size specific version having its GUI features redesigned to address certain erroneous interactions that were specific or more prevalent in that particular size.
In this document, relational terms such as first and second, top and bottom, and the like may be used solely to distinguish one entity or action from another entity or action without necessarily requiring or implying any actual such relationship or order between such entities or actions. The terms “comprises,” “comprising,” or any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. An element proceeded by “comprises . . . a” does not, without more constraints, preclude the existence of additional identical elements in the process, method, article, or apparatus that comprises the element.
It will be appreciated that embodiments of the disclosure described herein may be comprised of one or more conventional processors and unique stored program instructions that control the one or more processors to implement, in conjunction with certain non-processor circuits, some, most, or all of the functions of erroneous GUI interaction detection and GUI adaptation described herein. The non-processor circuits may include, but are not limited to, a radio receiver, a radio transmitter, signal drivers, clock circuits, power source circuits, and user input devices. As such, these functions may be interpreted as steps of a method to perform erroneous GUI interaction detection and GUI adaptation. Alternatively, some or all functions could be implemented by a state machine that has no stored program instructions, or in one or more application specific integrated circuits (ASICs), in which each function or some combinations of certain of the functions are implemented as custom logic. Of course, a combination of the two approaches could be used. Thus, methods and means for these functions have been described herein. Further, it is expected that one of ordinary skill, notwithstanding possibly significant effort and many design choices motivated by, for example, available time, current technology, and economic considerations, when guided by the concepts and principles disclosed herein will be readily capable of generating such software instructions and programs and ICs with minimal experimentation.
In the foregoing specification, specific embodiments of the present disclosure have been described. However, one of ordinary skill in the art appreciates that various modifications and changes can be made without departing from the scope of the present disclosure as set forth in the claims below. Accordingly, the specification and figures are to be regarded in an illustrative rather than a restrictive sense, and all such modifications are intended to be included within the scope of present disclosure. The benefits, advantages, solutions to problems, and any element(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential features or elements of any or all the claims. The disclosure is defined solely by the appended claims including any amendments made during the pendency of this application and all equivalents of those claims as issued.
Number | Name | Date | Kind |
---|---|---|---|
5119079 | Hube | Jun 1992 | A |
5565894 | Bates | Oct 1996 | A |
5627567 | Davidson | May 1997 | A |
6256021 | Singh | Jul 2001 | B1 |
6573844 | Venolia et al. | Jun 2003 | B1 |
8631358 | Louch | Jan 2014 | B2 |
8719001 | Izdepski | May 2014 | B1 |
9396092 | Kuo | Jul 2016 | B1 |
9645914 | Zhang | May 2017 | B1 |
20040178994 | Kairls, Jr. | Sep 2004 | A1 |
20060267957 | Kolmykov-Zotov | Nov 2006 | A1 |
20070174419 | O'Connell | Jul 2007 | A1 |
20070260749 | Lahdensivu | Nov 2007 | A1 |
20080172633 | Jeon | Jul 2008 | A1 |
20090150814 | Eyer | Jun 2009 | A1 |
20100299596 | Zalewski | Nov 2010 | A1 |
20110074685 | Causey et al. | Mar 2011 | A1 |
20110083104 | Minton | Apr 2011 | A1 |
20110242032 | Seo | Oct 2011 | A1 |
20110267280 | De Mers | Nov 2011 | A1 |
20120036468 | Colley | Feb 2012 | A1 |
20120147033 | Singhal | Jun 2012 | A1 |
20120169613 | Armstrong | Jul 2012 | A1 |
20130021243 | Lea | Jan 2013 | A1 |
20130044061 | Ashbrook | Feb 2013 | A1 |
20130069946 | Venon | Mar 2013 | A1 |
20130120278 | Cantrell | May 2013 | A1 |
20130120280 | Kukulski | May 2013 | A1 |
20130212487 | Cote | Aug 2013 | A1 |
20130246861 | Colley | Sep 2013 | A1 |
20140075244 | Takahashi | Mar 2014 | A1 |
20140184512 | Okuley | Jul 2014 | A1 |
20140184519 | Benchenaa | Jul 2014 | A1 |
20140223328 | Thomas | Aug 2014 | A1 |
20140282061 | Wheatley | Sep 2014 | A1 |
20140304689 | San Jose | Oct 2014 | A1 |
20140344061 | Choi | Nov 2014 | A1 |
20150160765 | Satou | Jun 2015 | A1 |
20150186128 | Patton | Jul 2015 | A1 |
20160188181 | Smith | Jun 2016 | A1 |
Number | Date | Country | |
---|---|---|---|
20160162276 A1 | Jun 2016 | US |