Video game systems may be configured to receive inputs from a variety of input devices, including but not limited to buttons, triggers and joysticks. Often, multiple input devices are incorporated into a single handheld controller body.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
In one disclosed example, a computing device input system comprises an input configured to receive a connection to a control device connector comprising a plurality of conductors. The computing device input system further comprises circuitry configured to determine a presence, type, and state of a control device in communication with the control device connector based on analog voltages received from the control device connector.
Gaming is a critical social outlet for many people with disabilities. However, most gamers with disabilities must rely on expensive aftermarket control hardware, the vast majority of which are hand built, one-off solutions. These custom-tailored devices and rigs are difficult to find, require technical expertise, may suffer from reliability problems due to the rework necessary, and can be very costly.
Gamers with disabilities and their caregivers often do not know where to look for assistive tech input devices, and may not have the technical ability to set up assistive technology hardware solutions.
Non-profits specialized in assistive gaming tech may help gamers with disabilities and their caregivers, but may have limited resources (e.g., funding, expertise, time) which results in backlogs, with many gamers waiting for expensive rigs. Gamers with disabilities, their caregivers, and associated non-profits may benefit from an off-the-shelf solution that is customizable for their input needs and physical abilities.
Accordingly, examples are disclosed herein that relate to human interface devices (HIDs) that have expansion capabilities for users. The described examples may be adapted for use by anyone, but may have special resonance for users with disabilities by enabling low cost interfaces with which to design multi-use HID devices.
Examples also relate to hardware and firmware interfaces that allow for an ecosystem of HID peripherals to be created that may enable gamers and other users to use HID devices for game play, office use, and other computer applications and accessibilities for daily life.
Such a computing device input system may include multiple input ports that enable accessibility to computing devices for people with disabilities, in particular for people with limited mobility, allowing them to couple joysticks, triggers, etc. that work for them to this input system. Further, such an input system may also be used by hardcore gamers who want to build their own customized control rigs.
Computing device input system 130 may include a plurality of inputs 160 that may be configured to receive a corresponding control device connector coupled to outputs 150. Computing device input system 130 is shown with four inputs 160, but more or fewer may be included in other examples. Inputs 160 may include identical input ports, or may include different input ports that are configured to interact with certain subsets of actuatable input mechanisms 140.
Herein, examples of outputs 150 and inputs 160 are described with regard to 3.5 mm connectors and input ports. However, other compatible input ports and connectors may also be used, such as 7 mm, USB, D-Sub connectors, D-Shell connectors, RJ 14 connectors, RJ 45 connectors, etc. provided the output connector includes a minimum number of conductor paths and/or contact points (e.g., two for a digital input mechanism, three for a trigger input mechanism, four for a thumbstick input mechanism).
Computing device input system 130 may be configured to receive information via the output voltages indicated by outputs 150. In this way, computing device input system 130 and control device 120 do not need to share a protocol, as per USB and other similar connectors. In this way, output 150 provides an interpretable set of analog characteristics than can be interpreted at computing device input system 130. As such, a USB input may be used to transfer analog voltage signals via the USB connector pins.
Computing device input system 130 may be coupled to computing device 110 via digital output 170. In this way, control device 120 and computing device input system 130 may be used as a HID for computing device 110. Digital output 170 may be any suitable digital output, such as USB, IDE, SATA, eSATA, firewire, lightning, ethernet, etc., as well as wireless technologies such as Bluetooth or Wi-Fi. Computing device 110 may be a gaming console, a personal computer, a device control interface (e.g., wheelchair control), etc.
Each input 160 may be configured to have multiple functions, and configured so that computing device input system 130 may automatically determine whether a connector is engaged with that input, automatically distinguish between different types of connected controls, and automatically determine a state of a connected control device. For example, generic TRS/TRRS connectors that are normally used for audio may be provided with features to distinguish buttons from potentiometers, etc. and/or to determine a status and/or position of such a connected actuatable input mechanism.
In some examples, digital input connectors may be used to convey signals from a control device to a computing device input system.
In this example, the detect pin is coupled to the left pin when no input connector is present through a normally-closed switch. In this conformation, pullup resistor 240 (e.g., connected to a ˜3.3V voltage rail), pulls all the way through to pull-down resistor 250, which is pulled down by ground. However, because resistor 240 is much stronger than resistor 250, the signal is pulled up. In this conformation, lower circuit 230 sees a logic-HIGH value.
When an input connector is present, the detect/left short is broken, sending the lower pin to ground. Lower circuit 230 sees a logic-LOW value. Thus, lower circuit 230 may output a detect signal that goes to a microcontroller that indicates whether a connector is plugged into digital input port 210. Firmware (or, in other examples, hardware or software logic) will not sample the signal port (upper circuit 220) unless a plugged-in status is confirmed by lower circuit 230. The illustrated diodes, resistors, & ESD diodes function as electrical protection circuitry to protect the circuit from overvoltage events, ESD events, etc. such as the case where an incompatible device is plugged into input port 210.
Pullup resistor 240 may be configured to be stronger than pulldown resistor 250 to help achieve this functionality. The resistance values may be set to achieve the logic-HIGH and logic-LOW signals. As shown, circuit 200 is essentially a voltage divider circuit. As such, when the detect and left pins are coupled (e.g., shorted together), the ratio of the voltage divider provides the logic-HIGH signal. When the pins are decoupled and the short is broken, the pulldown resistor goes to ground, providing the logic-LOW signal.
As an example, a firmware algorithm may include three stages—connector detection, polarity detection, and monitoring and reporting. For connector detection, the firmware may wait for lower circuit 230 to read low for a duration, such as 750 ms. This provides the user time to fully insert the connector into the input and allows the hardware to settle to a stable state before the firmware begins reading the digital control state.
Input devices communicate state information by shorting or opening an electrical connection between the left pin and the ground pin. For polarity detection, the firmware may sample the state of upper circuit 220 to determine its polarity (by assuming the digital control is not initially actuated). If the signal is high, the firmware may assume that the input device is normally open (high=unactuated, low=actuated). If the signal is low, the firmware may assume that the input device is normally closed (low=unactuated, high=actuated). Alternatively, the firmware may assume the polarity based on one or more other factors, or may query the user to provide polarity information via configuration reports.
For monitoring and reporting, the firmware may sample upper circuit 230 periodically to act on the digital control input state. The firmware may convert the digital input state into an actuated vs unactuated state using the determined polarity. The firmware may report the actuation state to one or more applications for processing. Monitoring may further include switch debounce, filtering, and/or hysteresis algorithms to increase accuracy and meet latency targets.
In other examples, analog control device connectors may be used to convey analog voltage signals from a control device to a computing device input system.
Various analog control device connectors may be used to interface with such an analog input.
TRRS connectors may be wired in other ways so as to convey multiple isolated analog voltage signals.
Connectors comprising wiring configurations 400 and 450 may be plugged into inputs that are specifically configured, or may be plugged into inputs configured to accept both wiring configurations 400 and 450. In such an example, a user may provide a configuration command to distinguish the two configurations, and/or firmware may detect the separate devices (e.g., via a weak pull-down resistor that would yield a detectable signal when overpowered by a joystick, but would be pulled to ground by an unconnected input).
For multi-purpose input ports, the input port circuitry may be configured such that an approximately linear response may be achieved on each analog output. Each input port may include a detect circuit coupled to a GPIO or ADC indicating whether a connector is plugged in (or unplugged from) the input port, wherein a first logic status (one of HIGH and LOW) indicates a plugged-in status, and a second logic status (the other of HIGH and LOW) indicates an unplugged status. Each input port may include a diode clamping circuit used to protect the input ports from excessive voltage. Data output by each ADC may be analyzed and processed by the firmware by utilizing switch debounce, filtering, and/or hysteresis algorithms to allow for a good user response.
As an example,
GPIO 723 may be used to determine if a connector is coupled to input port 710. Comparator 725 may be used instead of the resister/divider pair shown in
In this example, the voltage at ADC 720 will be VCC/2 when a TS connector is present, as the MIC and GND pins become shorted together. The voltage at ADC 720 will be equal to VCC when a TRRS connector is present. For example, if a TS connector coupled to a normally open button (such as described with regard to
Grounding resistor 730, coupled to ADC 721, allows port 710 to accept both TS and TRRS connectors and to accurately detect the state of both types of input devices. Port 710 supports both normally open and normally closed buttons that can be actuated. TS connectors have an isolated left pin, with ground, right, and mic pins shorted together. Actuation for normally open buttons causes the left pin (T) to be shorted to the ground pin (S). If the button is not actuated, the circuit remains open. Actuation for normally closed buttons causes the left pin (T) to be isolated from the ground pin (S). If the button is not actuated, the left pin (T) will remain shorted to the ground pin (S). When shorted to ground, the ground pin is set to middle voltage via the voltage divider between pullup resistor 735 (coupled to MIC) and grounding resistor 740 (coupled to GND). The resulting voltage is predominant on ADC 721. When the button is released, the left pin is opened, and grounding resistor 730 pulls it down. In other words, in one state the voltage at ADC 721 is middle voltage. In another state, the voltage is based on grounding resistor 730. Grounding resistor 730 helps to determine the button state, but may introduce non-linearity for a thumbstick. Thus, the value of grounding resistor 730 may be selected to obtain a good button response while maintaining a suitable degree of linearity.
ADC 721 is thus coupled to the positive rail of comparator 725 for plugged/unplugged detection, determination of TS vs TRRS connector type, and is used for either determining a button status or for indicating the X direction of a joystick. Grounding resistor 730 enables this function overload of ADC 721.
At 810, method 800 includes determining whether a connector is plugged into or unplugged from an input port based on the output of a GPIO coupled to a detect pin within an input port (e.g., GPIO 723). For connector detection, the firmware may wait for the GPIO to read high for a duration, such as 750 ms. This provides the user time to fully insert the plug and allows the hardware to settle to a stable state before the firmware begins reading the digital control state.
At 820, method 800 includes classifying an actuatable input mechanism coupled to a plugged-in connector based on an output of a first ADC coupled to the mic pin of the input port (e.g., ADC 720). If the voltage is within a threshold of VCC, the input mechanism may be classified as an analog joystick control. If the voltage is near VCC/2, the input mechanism may be classified as a digital control (e.g., button).
At 830, method 800 includes determining a polarity of the actuatable input mechanism based on an output of a second ADC coupled to the left pin of the input port (e.g., ADC 721). For input mechanisms classified as digital controls, the firmware may sample the second ADC input to determine its polarity, which may include assuming the digital control is not actuated initially. If the sampled signal is low, the firmware may assume the input mechanism is normally open (low=unactuated, VCC/2=actuated). If the sampled signal is near VCC/2, the firmware may assume the input device is normally closed (VCC/2=unactuated, low=actuated). Alternatively, the firmware may assume the polarity based on one or more additional factors, or may query the user to provide polarity information via configuration reports.
At 840, method 800 includes monitoring and reporting a status of the actuatable input mechanism based on the outputs of the second ADC and a third ADC coupled to the right pin of the input port (e.g., ADC 722). For example, the firmware may sample the left and right channel ADC inputs periodically to act on the control's input state. For analog controls, the firmware may interpret the value from the second ADC as the X-axis position, and the value from the third ADC as the Y-axis position. Dynamic range, linearity, and deadzones can be handled via specification or via calibration. Any joystick position changes may be reported to an application for action. For digital controls, the digital input state may be converted into an actuated vs unactuated state based on the results from polarity detection. The actuation state may be reported to an application for processing. Additional monitoring may include standard switch debouncing, filtering, or hysteresis algorithms to increase accuracy and meet latency targets.
A firmware algorithm may include two stages: plug detection, and monitoring and reporting. As described with regard to
For monitoring and reporting, the firmware may sample ADC 920 periodically to act on the control's input state. The value at ADC 920 may be interpreted as trigger position. Dynamic range, linearity, and deadzones can be handled via specification or via calibration. Any trigger position changes may be reported to an application for action. This firmware method may work with both analog triggers as well as digital switches. Digital switches may function similarly to a single-channel potentiometer-based trigger, excepting that the dynamic range may differ. Any differences in dynamic range may be handled by the calibration or specification process.
In some embodiments, the methods and processes described herein may be tied to a computing system of one or more computing devices. In particular, such methods and processes may be implemented as a computer-application program or service, an application-programming interface (API), a library, and/or other computer-program product.
Computing system 1000 includes a logic machine 1010 and a storage machine 1020. Computing system 1000 may optionally include a display subsystem 1030, input subsystem 1040, communication subsystem 1050, and/or other components not shown in
Logic machine 1010 includes one or more physical devices configured to execute instructions. For example, the logic machine may be configured to execute instructions that are part of one or more applications, services, programs, routines, libraries, objects, components, data structures, or other logical constructs. Such instructions may be implemented to perform a task, implement a data type, transform the state of one or more components, achieve a technical effect, or otherwise arrive at a desired result.
The logic machine may include one or more processors configured to execute software instructions. Additionally or alternatively, the logic machine may include one or more hardware or firmware logic machines configured to execute hardware or firmware instructions. Processors of the logic machine may be single-core or multi-core, and the instructions executed thereon may be configured for sequential, parallel, and/or distributed processing. Individual components of the logic machine optionally may be distributed among two or more separate devices, which may be remotely located and/or configured for coordinated processing. Aspects of the logic machine may be virtualized and executed by remotely accessible, networked computing devices configured in a cloud-computing configuration.
Storage machine 1020 includes one or more physical devices configured to hold instructions executable by the logic machine to implement the methods and processes described herein. When such methods and processes are implemented, the state of storage machine 1020 may be transformed—e.g., to hold different data.
Storage machine 1020 may include removable and/or built-in devices. Storage machine 1020 may include optical memory (e.g., CD, DVD, HD-DVD, Blu-Ray Disc, etc.), semiconductor memory (e.g., RAM, EPROM, EEPROM, etc.), and/or magnetic memory (e.g., hard-disk drive, floppy-disk drive, tape drive, MRAM, etc.), among others. Storage machine 1020 may include volatile, nonvolatile, dynamic, static, read/write, read-only, random-access, sequential-access, location-addressable, file-addressable, and/or content-addressable devices.
It will be appreciated that storage machine 1020 includes one or more physical devices. However, aspects of the instructions described herein alternatively may be propagated by a communication medium (e.g., an electromagnetic signal, an optical signal, etc.) that is not held by a physical device for a finite duration.
Aspects of logic machine 1010 and storage machine 1020 may be integrated together into one or more hardware-logic components. Such hardware-logic components may include field-programmable gate arrays (FPGAs), program- and application-specific integrated circuits (PASIC/ASICs), program- and application-specific standard products (PSSP/ASSPs), system-on-a-chip (SOC), and complex programmable logic devices (CPLDs), for example.
When included, display subsystem 1030 may be used to present a visual representation of data held by storage machine 1020. This visual representation may take the form of a graphical user interface (GUI). As the herein described methods and processes change the data held by the storage machine, and thus transform the state of the storage machine, the state of display subsystem 1030 may likewise be transformed to visually represent changes in the underlying data. Display subsystem 1030 may include one or more display devices utilizing virtually any type of technology. Such display devices may be combined with logic machine 1010 and/or storage machine 1020 in a shared enclosure, or such display devices may be peripheral display devices.
When included, input subsystem 1040 may comprise or interface with one or more user-input devices such as a keyboard, mouse, touch screen, or game controller. In some embodiments, the input subsystem may comprise or interface with selected natural user input (NUI) componentry. Such componentry may be integrated or peripheral, and the transduction and/or processing of input actions may be handled on- or off-board. Example NUI componentry may include a microphone for speech and/or voice recognition; an infrared, color, stereoscopic, and/or depth camera for machine vision and/or gesture recognition; a head tracker, eye tracker, accelerometer, and/or gyroscope for motion detection and/or intent recognition; as well as electric-field sensing componentry for assessing brain activity.
When included, communication subsystem 1050 may be configured to communicatively couple computing system 1000 with one or more other computing devices. Communication subsystem 1050 may include wired and/or wireless communication devices compatible with one or more different communication protocols. As non-limiting examples, the communication subsystem may be configured for communication via a wireless telephone network, or a wired or wireless local- or wide-area network. In some embodiments, the communication subsystem may allow computing system 1000 to send and/or receive messages to and/or from other devices via a network such as the Internet.
In another example, a computing device input system comprises an input configured to receive a connection to a control device connector comprising a plurality of conductors; and circuitry configured to determine a presence, type, and state of a control device in communication with the control device connector based on analog voltages received from the control device connector. In such an example, or any other example, the control device connector may additionally or alternatively comprise an analog audio jack. In any of the preceding examples, or any other example, the control device may additionally or alternatively comprise one or more potentiometers. In any of the preceding examples, or any other example, the control device may additionally or alternatively comprise a switch. In any of the preceding examples, or any other example, the computing device input system may additionally or alternatively comprise a plurality of inputs. In any of the preceding examples, or any other example, the plurality of inputs may additionally or alternatively comprise an analog input and a digital input each comprising circuitry configured to determine a type of control device connected. In any of the preceding examples, or any other example, the control device connector may additionally or alternatively comprise one of a USB, RJ 14, and RJ 45 connector. In any of the preceding examples, or any other example, the computing device input system may additionally or alternatively be a video game controller system.
In another example, a computing device input system comprises an input port including ground, left, detect, right, and mic pins, the left pin and detect pin being shorted together in the absence of a plugged-in connector; a first analog-to-digital converter (ADC) coupled to the left pin; a general-purpose input/output (GPIO) coupled to the detect pin via a comparator; a pullup resistor coupled to the mic pin; a first grounding resistor coupled between the ground pin and ground; a second grounding resistor coupled between the left pin and ground; and a controller configured to receive voltages from the first ADC and the GPIO, and further configured to indicate a presence of a plugged-in connector based on a voltage received from the GPIO, and indicate a type of actuatable input mechanism coupled to the plugged-in connector based on a voltage received from the first ADC. In such an example, or any other example, the system may additionally or alternatively comprise a second ADC coupled to the mic pin; and the controller may additionally or alternatively be further configured to receive voltages from the second ADC, and indicate a type of actuatable input mechanism coupled to the plugged-in connector based on a voltage received from the second ADC. In any of the preceding examples, or any other example, the controller may additionally or alternatively be configured to indicate a type of actuatable input mechanism coupled to the plugged-in connector by indicating that a TS connector is plugged in to the input port based on receiving a voltage of VCC/2 from the first ADC. In any of the preceding examples, or any other example, the controller may additionally or alternatively be configured to indicate that a button is in an open state based on receiving a voltage from the first ADC, the received voltage based on a voltage divider between the pull-up resistor and the first grounding resistor. In any of the preceding examples, or any other example, the controller may additionally or alternatively be configured to indicate that the button is in a closed state based on receiving a voltage from the first ADC, the received voltage based on a value of the second grounding resistor. In any of the preceding examples, or any other example, the controller may additionally or alternatively be further configured to indicate a type of actuatable input mechanism coupled to the plugged-in connector by indicating that a TRRS connector is plugged in to the input port based on receiving a voltage of VCC from the first ADC. In any of the preceding examples, or any other example, the system may additionally or alternatively comprise a third ADC coupled to the right pin, and the controller may additionally or alternatively be further configured to indicate X and Y potentiometer values based on voltages received from the second and third ADCs.
In yet another example, a method for processing analog voltage signals received at an input port of a computing device input system comprises: determining whether a connector is plugged into or unplugged from an input port based on the output of a GPIO coupled to a first pin within the input port; classifying an actuatable input mechanism coupled to a plugged-in connector based on an output of a first ADC coupled to a second pin of the input port; determining a polarity of the actuatable input mechanism based on an output of a second ADC coupled to a third pin of the input port; and monitoring and reporting a status of the actuatable input mechanism based on the outputs of the second ADC and a third ADC coupled to a fourth pin of the input port. In such an example, or any other example, determining whether a connector is plugged into or unplugged from an input port based on the output of a GPIO may additionally or alternatively comprise waiting for the GPIO to read a high voltage value for a predetermined duration. In any of the preceding examples, or any other example, classifying an actuatable input mechanism coupled to a plugged-in connector based on an output of the first ADC may additionally or alternatively include classifying the actuatable input mechanism as an analog joystick based on an output of the first ADC being within a threshold of VCC; and classifying the actuatable input mechanism as a digital control based on an output of the first ADC being within a threshold of VCC/2. In any of the preceding examples, or any other example, determining a polarity of the actuatable input mechanism based on an output of the second ADC may additionally or alternatively include indicating the actuatable input mechanism is normally closed based on an output of the second ADC being within a threshold of ground voltage; and indicating the actuatable input mechanism is normally open based on an output of the second ADC being within a threshold of VCC/2. In any of the preceding examples, or any other example, monitoring and reporting a status of the actuatable input mechanism based on the outputs of the second ADC and the third ADC may additionally or alternatively include indicating an X-axis position of a joystick based on a voltage received from the second ADC; and indicating a Y-axis position of the joystick based on a voltage received from the third ADC.
It will be understood that the configurations and/or approaches described herein are exemplary in nature, and that these specific embodiments or examples are not to be considered in a limiting sense, because numerous variations are possible. The specific routines or methods described herein may represent one or more of any number of processing strategies. As such, various acts illustrated and/or described may be performed in the sequence illustrated and/or described, in other sequences, in parallel, or omitted. Likewise, the order of the above-described processes may be changed.
The subject matter of the present disclosure includes all novel and non-obvious combinations and sub-combinations of the various processes, systems and configurations, and other features, functions, acts, and/or properties disclosed herein, as well as any and all equivalents thereof.
This application claims priority to U.S. Provisional Application Ser. No. 62/596,110, filed Dec. 7, 2017, the entirety of which is incorporated by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
62596110 | Dec 2017 | US |