Library to handle the X-NUCLEO-LED61A1 LED Control Expansion Board based on the LED6001 component.
Dependents: LedDimming_LED61A1_mbedOS HelloWorld_LED61A1_mbedOS LedDimming_LED61A1 HelloWorld_LED61A1 ... more
Fork of X_NUCLEO_LED61A1 by
Led.h
00001 /** 00002 ****************************************************************************** 00003 * @file Led.h 00004 * @author AST 00005 * @version V1.0.0 00006 * @date April 13th, 2015 00007 * @brief This file contains the abstract class describing the interface of a 00008 * led component. 00009 ****************************************************************************** 00010 * @attention 00011 * 00012 * <h2><center>© COPYRIGHT(c) 2015 STMicroelectronics</center></h2> 00013 * 00014 * Redistribution and use in source and binary forms, with or without modification, 00015 * are permitted provided that the following conditions are met: 00016 * 1. Redistributions of source code must retain the above copyright notice, 00017 * this list of conditions and the following disclaimer. 00018 * 2. Redistributions in binary form must reproduce the above copyright notice, 00019 * this list of conditions and the following disclaimer in the documentation 00020 * and/or other materials provided with the distribution. 00021 * 3. Neither the name of STMicroelectronics nor the names of its contributors 00022 * may be used to endorse or promote products derived from this software 00023 * without specific prior written permission. 00024 * 00025 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00026 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00027 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00028 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE 00029 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00030 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 00031 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00032 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00033 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 00034 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00035 * 00036 ****************************************************************************** 00037 */ 00038 00039 00040 /* Generated with STM32CubeTOO -----------------------------------------------*/ 00041 00042 00043 /* Revision ------------------------------------------------------------------*/ 00044 /* 00045 Repository: http://svn.x-nucleodev.codex.cro.st.com/svnroot/X-NucleoDev 00046 Branch/Trunk/Tag: trunk 00047 Based on: X-CUBE-LED1/trunk/Drivers/BSP/Components/Common/led.h 00048 Revision: 0 00049 */ 00050 00051 00052 /* Define to prevent recursive inclusion -------------------------------------*/ 00053 00054 #ifndef __LED_CLASS_H 00055 #define __LED_CLASS_H 00056 00057 00058 /* Includes ------------------------------------------------------------------*/ 00059 00060 #include <Component.h> 00061 00062 00063 /* Classes ------------------------------------------------------------------*/ 00064 00065 /** An abstract class for Led components. 00066 */ 00067 class Led : public Component 00068 { 00069 public: 00070 /* ACTION 1 --------------------------------------------------------------* 00071 * Declare here the interface's methods. * 00072 * They should be: * 00073 * + Methods with the same name of the C component's virtual table * 00074 * (and extended virtual table, if any)'s functions, provided that * 00075 * the component's driver implements them (i.e.: the corresponding * 00076 * pointer to function is not "0"). * 00077 * * 00078 * Example: * 00079 * virtual int get_value(float *f) = 0; * 00080 *------------------------------------------------------------------------*/ 00081 /** 00082 * @brief Getting the current flowing through the LED. 00083 * @param None. 00084 * @retval The current flowing through the LED, represented as a floating 00085 * point number in the range [0.0, 1.0]. 00086 */ 00087 virtual float get_current(void) = 0; 00088 00089 /** 00090 * @brief Setting PWM dimming value. 00091 * @param dimming PWM dimming value. 00092 * @retval None. 00093 */ 00094 virtual void set_pwm_dimming(float dimming) = 0; 00095 00096 /** 00097 * @brief Setting Analog dimming value. 00098 * @param dimming Analog dimming value. 00099 * @retval None. 00100 */ 00101 virtual void set_analog_dimming(float dimming) = 0; 00102 00103 /** 00104 * @brief Destructor. 00105 */ 00106 virtual ~Led() {}; 00107 }; 00108 00109 #endif /* __LED_CLASS_H */ 00110 00111 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Generated on Mon Jul 18 2022 02:55:00 by 1.7.2