ReadAnalogChannel()

Purpose

Get the value of an Analog Channel (joystick) on a remote controller connected to the CrcDuino via a CrcConnect module.

When to use

Whenever you need to use the position of a remote controller joystick or triggers.

Where to use

Most probably in the void loop() part of your .ino file, since we’d usually want to actively monitor the value.

Click here to learn more on the CrcConnect system, that allows to control a CrcDuino using popular off-the-shelf remote controllers.

If not connection is established with a remote controller via a CrcConnect module, ReadAnalogChannel() returns a value of 0. Depending on the application, it might be useful to validate the status of the connection using IsCommValid().

This function requires the use of the following CrcLib functions at some point of your .ino file in order to work properly:

Returns

This function returns the value of the analog channel mentioned as the function’s argument as a signed chartype. The value returned will range between -128 and 127, proportionally to the position of the joystick or trigger. The returned value will be:

  • -128, if the

    • Joystick is at the maximum left position (for x axis channels)

    • Joystick is at the maximum up position (for y axis channels)

    • Trigger is fully unpressed

  • 0, if the joystick/trigger is at the middle position of the axis, or if no connection is established between a remote controller and the CrcDuino (via a CrcConnect Module)

  • 127, if the

    • Joystick is at the maximum right position (for x axis channels)

    • Joystick is at the maximum down position (for y axis channels)

    • Trigger is fully pressed

Main prototype and parameters

static int8_t CrcLib::ReadAnalogChannel(ANALOG channel)

The following parameters must be passed to the function for it to work properly:

  • channel: The name of the joystick channel you want to read the value of. Must be of the type ANALOG.

Overloads

This function does not have any overloads. It can only be used as described by the main prototype.

Examples

#include <CrcLib.h> signed char joystickValue; void setup() { CrcLib::Initialize(); Serial.begin(2000000); //Open the serial Monitor at a 2000000 baud rate /* The rest of your setup code ... */ } void loop() { CrcLib::Update(); joystickValue = CrcLib::ReadAnalogChannel(ANALOG::JOYSTICK1_X); Serial.println(joystickValue); /* The rest of your looping code ... */ }

More on this function

There is sadly nothing more to be said about this function…

Related articles