HCSR04 library with public trigger

Fork of HCSR04 by Prabhu Desai

hcsr04.cpp

Committer:
prabhuvd
Date:
2013-03-30
Revision:
4:33938a97d904
Parent:
3:e6795cb9439c
Child:
5:e70a24a88131

File content as of revision 4:33938a97d904:

/* Copyright (c) 2013 Prabhu Desai
 * pdtechworld@gmail.com
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
 * and associated documentation files (the "Software"), to deal in the Software without restriction,
 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all copies or
 * substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */


#include "hcsr04.h"


DistMeasure::DistMeasure(PinName TrigPin,PinName EchoPin):
    trigger(TrigPin), echo(EchoPin)
{
    pulsetime.stop();
    pulsetime.reset();
    echo.rise(this,&DistMeasure::isr_rise);
    echo.fall(this,&DistMeasure::isr_fall);
    trigger=0;
}

DistMeasure::~DistMeasure()
{
}

void DistMeasure::isr_rise(void)
{
    pulsetime.start();
}
void DistMeasure::start(void)
{
    trigger=1;
    wait_us(10);
    trigger=0;
}

void DistMeasure::isr_fall(void)
{
    pulsetime.stop();
    pulsedur = pulsetime.read_us();
    distance= (pulsedur*343)/20000;
    pulsetime.reset();
}

void DistMeasure::rise (void (*fptr)(void))
{
    echo.rise(fptr);
}
void DistMeasure::fall (void (*fptr)(void))
{
    echo.fall(fptr);
}

unsigned int DistMeasure::get_dist_cm()
{
    return distance;
}
unsigned int DistMeasure::get_pulse_us()
{
    return pulsedur;
}