read()

Description

Function to read the encoder’s counter value and pulse width.
Note: Under different mode, the return value has different representation. See the Returns section below.

Syntax


Enc0.read()
Enc1.read()
Enc2.read()
Enc3.read()

Parameters

Enc0、Enc1、Enc2、Enc3:Corresponding to ENC0, ENC1, ENC2 and ENC3 encoder interfaces.

Returns

Pulse/DIR, CW/CCW and A/B Pulse modes: Return the encoder’s counter value.

PWM pulse capture mode: Return the pulse width value for digital HIGH or LOW condition in micro-second (us), where the maximum value is 71 minutes. (Note: Under this mode, the read() function can only be called within an associated ISR function. When using this function elsewhere, it always return 0.)

SSI mode: Return SSI absolute value from the encoder.

Example

Set ENCO to A/B Pulse mode, and read the encoder’s counter value.

#include <Encoder.h>

void setup() {
  Serial.begin(9600);
  Enc0.begin(MODE_AB_PHASE);
}

void loop() {
  Serial.println(Enc0.read());// Read encoder counter value
  delay(100);
}

Set ENC1 to PWM pulse capture mode, read the pulse width for digital HIGH and LOW condition.

#include <Encoder.h>

volatile unsigned long num1 = 0L;
volatile unsigned long num2 = 0L;
void encoder_isr(int flag) { // ISR function
    if (flag == INTR_A_PULSE_LOW)// Read pulse width during digital LOW condition
      num1 = Enc1.read();
    else if (flag == INTR_A_PULSE_HIGH) // Read pulse width during digital HIGH condition
      num2 = Enc1.read();
}

void setup() {
   Serial.begin(9600);
   Enc1.begin(MODE_CAPTURE);
   Enc1.attachInterrupt(encoder_isr);// Mount ISR function and enable interrupt
}

void loop() {
   Serial.print("LOW:");
   Serial.print(num1); // Output pulse width during digital LOW condition in micro-second (us)
   Serial.print("    ");
   Serial.print("HIGH:");
   Serial.println(num2); // Output pulse width during digital HIGH condition in micro-second (us)
   delay(100);
}

See also

attachInterrupt()


Libraries Reference Home

The text of the 86Duino reference is licensed under a Creative Commons Attribution-ShareAlike 3.0 License. Code samples in the reference are released into the public domain.