upm/src/sx6119/sx6119.h
Jon Trulson 34b28928de sx6119: Initial implementation
This was tested with the Grove FM Receiver.  Unfortunately, there is
no documentation on how to control the device using the D1 and D2 pins
that Seeed provides.  There is a switch on the device that can control
all of the elements, power, volume, and seek +/-.

The supplied example can turn the device on, and do a seek, but not
much else.

Signed-off-by: Jon Trulson <jtrulson@ics.com>
Signed-off-by: Zion Orent <zorent@ics.com>
Signed-off-by: Mihai Tudor Panu <mihai.tudor.panu@intel.com>
2015-05-06 17:30:08 -07:00

88 lines
2.4 KiB
C++

/*
* Author: Jon Trulson <jtrulson@ics.com>
* Copyright (c) 2015 Intel Corporation.
*
* 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.
*/
#pragma once
#include <iostream>
#include <mraa/gpio.h>
namespace upm {
/**
* @brief UPM support for the SX6119 based FM Receiver
* @defgroup sx6119 libupm-sx6119
* @ingroup seeed gpio sound
*/
/**
* @sensor sx6119
* @library sx6119
* @comname Grove FM Receiver v1.0
* @type sound
* @man seeed
* @con gpio
*
* @brief C++ API support for the SX6119 based Grove FM Receiver
*
* This class implements support for the FM Receiver. There are
* two digital pins, one that toggles power on/off, and one that
* does a seek to the next station.
*
* @snippet sx6119.cxx Interesting
*/
class SX6119 {
public:
/**
* SX6119 module constructor
*
* @param powerPin the pin to use for recording
* @param seekPin the pin to use to seek to the next station
*/
SX6119(int powerPin, int seekPin);
/**
* SX6119 module Destructor
*/
~SX6119();
/**
* Toggle the device power on or off
*
*/
void togglePower();
/**
* Seek to the next station
*
*/
void seek();
private:
mraa_gpio_context m_gpioPower;
mraa_gpio_context m_gpioSeek;
};
}