display 7 seg 4 digitos

Dependencies:   mbed TextLCD

Committer:
Antulius
Date:
Fri Oct 25 21:18:37 2019 +0000
Revision:
0:8006a686f427
display 7 seg 4 digitos

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Antulius 0:8006a686f427 1 /* ###########################################################################
Antulius 0:8006a686f427 2 ** Archivo : main.c
Antulius 0:8006a686f427 3 ** Proyecto : STM32-103C8_Barrido_Display
Antulius 0:8006a686f427 4 ** Procesador : STM32F103C8
Antulius 0:8006a686f427 5 ** Herramienta : Mbed
Antulius 0:8006a686f427 6 ** Version : Driver 01.01
Antulius 0:8006a686f427 7 ** Compilador : GNU C Compiler
Antulius 0:8006a686f427 8 ** Fecha/Hora : 14-07-2015, 11:48, # CodeGen: 0
Antulius 0:8006a686f427 9 ** Descripción :
Antulius 0:8006a686f427 10 ** Este proyecto hace...
Antulius 0:8006a686f427 11 ** This module contains user's application code.
Antulius 0:8006a686f427 12 ** Componentes : GPIO, Timer, etc .
Antulius 0:8006a686f427 13 ** Configuraciones : Includes, Stacks y Drivers externos
Antulius 0:8006a686f427 14 ** Autores :
Antulius 0:8006a686f427 15 ** ATEAM Development Group:
Antulius 0:8006a686f427 16 ** - Antulio Morgado Valle
Antulius 0:8006a686f427 17 **
Antulius 0:8006a686f427 18 ** Versión : Beta
Antulius 0:8006a686f427 19 ** Revisión : A
Antulius 0:8006a686f427 20 ** Release : 0
Antulius 0:8006a686f427 21 ** Bugs & Fixes :
Antulius 0:8006a686f427 22 ** Date : 20/10/2019
Antulius 0:8006a686f427 23 ** Added support for Led_RGB
Antulius 0:8006a686f427 24 ** 22/09/2018
Antulius 0:8006a686f427 25 ** Added LCD Menu, Beta version (with bugs)
Antulius 0:8006a686f427 26 **
Antulius 0:8006a686f427 27 ** ###########################################################################*/
Antulius 0:8006a686f427 28 /*
Antulius 0:8006a686f427 29 ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
Antulius 0:8006a686f427 30 : Includes
Antulius 0:8006a686f427 31 ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
Antulius 0:8006a686f427 32 */
Antulius 0:8006a686f427 33 #include "stm32f103c8t6.h"
Antulius 0:8006a686f427 34 #include "mbed.h"
Antulius 0:8006a686f427 35 #include "AnalogIn.h"
Antulius 0:8006a686f427 36 //#include "ADC.h"
Antulius 0:8006a686f427 37 //#include "Led_RGB.h"
Antulius 0:8006a686f427 38 #include "Serial.h"
Antulius 0:8006a686f427 39 #include "TextLCD.h"
Antulius 0:8006a686f427 40 #include "I2C.h"
Antulius 0:8006a686f427 41 #include "SPI.h"
Antulius 0:8006a686f427 42 #include "stdio.h"
Antulius 0:8006a686f427 43 /*
Antulius 0:8006a686f427 44 :...............................................................................
Antulius 0:8006a686f427 45 : Definiciones
Antulius 0:8006a686f427 46 :...............................................................................
Antulius 0:8006a686f427 47 */
Antulius 0:8006a686f427 48 #define on 0 // Estado para boton presionado
Antulius 0:8006a686f427 49 #define off 1 // Estado para boton sin presionar
Antulius 0:8006a686f427 50 #define hold 2 // Estado para boton mantenido
Antulius 0:8006a686f427 51 #define release 3 // Estado para boton liberado
Antulius 0:8006a686f427 52 #define FALSE 0 // Estado FALSO
Antulius 0:8006a686f427 53 #define TRUE 1 // Estado VERDADERO
Antulius 0:8006a686f427 54 #define Ticker_Rate 1000 // Periodo de interrupción (us)
Antulius 0:8006a686f427 55 #define Rate_Time 2 // Tiempo de Encendido de los Digitos (ms)
Antulius 0:8006a686f427 56 #define Scan_Time 2 // Tiempo de Barrido del Display (ms)
Antulius 0:8006a686f427 57 #define Shift_Time 2 // Tiempo de corrimiento (x Counter_Time)
Antulius 0:8006a686f427 58 #define Counter_Time 100 // Tiempo de counter (ms)
Antulius 0:8006a686f427 59 #define Size_String 20 // Tamaño del Buffer de Caracteres
Antulius 0:8006a686f427 60 #define Digit_Null 0xFF // Valor para apagar los Segmentos
Antulius 0:8006a686f427 61 #define Degree_Symbol 0x0F // Valor para el Símbolo de Grados
Antulius 0:8006a686f427 62 /*
Antulius 0:8006a686f427 63 +-------------------------------------------------------------------------------
Antulius 0:8006a686f427 64 | Configuración de Puertos
Antulius 0:8006a686f427 65 +-------------------------------------------------------------------------------
Antulius 0:8006a686f427 66 */
Antulius 0:8006a686f427 67
Antulius 0:8006a686f427 68 DigitalOut led_monitor(LED1); // Inicializa el Led de Monitor
Antulius 0:8006a686f427 69 PwmOut buzzer (PB_1); // PWM para el Buzzer
Antulius 0:8006a686f427 70 AnalogIn sensor1 (PA_0); // Canal Analógico para sensor 1
Antulius 0:8006a686f427 71 AnalogIn sensor2 (PA_1); // Canal Analógico para sensor 2
Antulius 0:8006a686f427 72 BusIn Teclado (PB_5,PB_6,PB_7,PB_8); // Teclado Matricial
Antulius 0:8006a686f427 73 BusOut Anodos (PB_12, PB_13, PB_14, PB_15); // Anodos: (Uni Dec Cent Mill) A1 A2 A3 A4
Antulius 0:8006a686f427 74 BusOut Catodos (PB_4,PB_3,PA_15,PA_12,PA_11,PA_10,PA_9,PA_8); // Cátodos: p e d c b a f g
Antulius 0:8006a686f427 75 // ***** Host PC Terminal Communication channels
Antulius 0:8006a686f427 76 Serial Terminal (PA_2, PA_3); // Inicializa la comunicación serial a la PC (Tx,Rx)
Antulius 0:8006a686f427 77 //Serial Terminal(USBTX, USBRX,115200);// Tx, Rx Baud Rate - Terminal Serial por USB @ 115,200 Bauds
Antulius 0:8006a686f427 78 // ***** I2C Communication
Antulius 0:8006a686f427 79 //I2C i2c_LCD(PB_9,PB_8,); // SDA, SCL
Antulius 0:8006a686f427 80 // ***** SPI Communication
Antulius 0:8006a686f427 81 //SPI spi_LCD(PA_7,PA_6,PA_5,PB_6); // MOSI, MISO, SCLK, SS
Antulius 0:8006a686f427 82 Ticker Barrido; // Interrupción por Timer
Antulius 0:8006a686f427 83 /*
Antulius 0:8006a686f427 84 ** -------------------------------------------------------------------
Antulius 0:8006a686f427 85 ** Instanciación del LCD
Antulius 0:8006a686f427 86 ** -------------------------------------------------------------------
Antulius 0:8006a686f427 87 */
Antulius 0:8006a686f427 88 // LCD instantiation
Antulius 0:8006a686f427 89 //TextLCD lcd(PTC5, PTC6, PTC8, PTC9, PTC10, PCT11, TextLCD::LCD20x2); // 4bit bus: rs, e, d4-d7
Antulius 0:8006a686f427 90 //TextLCD_SPI lcd(&spi_LCD, PB_6, TextLCD::LCD16x4, TextLCD::AC780); // SPI bus, CS, LCD Type
Antulius 0:8006a686f427 91 //TextLCD_I2C lcd(&i2c_LCD, 0x7E, TextLCD::LCD20x4); // I2C bus, PCF8574A Arduino Shield, LCD Type
Antulius 0:8006a686f427 92
Antulius 0:8006a686f427 93 /*
Antulius 0:8006a686f427 94 +-------------------------------------------------------------------------------
Antulius 0:8006a686f427 95 | Variables Globales de Usuario
Antulius 0:8006a686f427 96 +-------------------------------------------------------------------------------
Antulius 0:8006a686f427 97 */
Antulius 0:8006a686f427 98 uint16_t Rate=1000; // Velocidad de barrido (1000us = 1ms)
Antulius 0:8006a686f427 99 // ++++++++++++++++++++ Generador de Caracteres ++++++++++++++++++++++++++++++++
Antulius 0:8006a686f427 100 // Offset: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
Antulius 0:8006a686f427 101 // Caracter: 0 1 2 3 4 5 6 7 8 9 A b C d E f G h I j K L M n o P q r S t u V W X y Z null a e +o +/c c /c +u +n [ ] ° ^ ¬ + > ^ / v < v > /_ - _ = /= == ¬_ ii # /# J /J -J -/J -J -/J | || + /+ null ! " # $ % & ' ( ) * + - . / : ; < > ? @
Antulius 0:8006a686f427 102 uint8_t Segmentos[]={0x81,0xE7,0x49,0x43,0x27,0x13,0x11,0xC7,0x01,0x03,0x05,0x31,0x99,0x61,0x19,0x1D,0x91,0x35,0xBD,0xB3,0x2D,0xB9,0x85,0x75,0x71,0x0D,0x07,0x3D,0x13,0x39,0xF1,0xE1,0xA1,0x25,0x37,0x49,0xFF,0xBE,0xF6,0x0F,0x8F,0x4F,0x2F,0x1F,0x0F,0x13,0x01,0x7F,0x7D,0x7B,0x79,0x75,0x73,0x71,0x70,0x99,0xC3,0x3F,0x9F,0xCF,0x6F,0x7D,0xF9,0xF3,0xD7,0xF7,0xDF,0x7F,0xFB,0x5F,0x7B,0x5B,0xBD,0xF5,0x6D,0x37,0xE3,0xB9,0x9D,0x7C,0xE7,0xBD,0xCa,0x00};
Antulius 0:8006a686f427 103 // ++++++++++++++++++++++ Selector de Digitos ++++++++++++++++++++++++++++++++++
Antulius 0:8006a686f427 104 uint8_t Digitos[]={0x08,0x04,0x02,0x01,0x00,0x0F}; // Millares, Centenas, Decenas, Unidades, Apagados, Encendidos
Antulius 0:8006a686f427 105 uint8_t Numeros[]={1,0,2,4}; // Valor a Desplegar
Antulius 0:8006a686f427 106 uint8_t Cadena[]={33,0,21,10,36,14,28,18,22,36,35,10,12,10,29,14,23,12,24,36,36}; // Mensaje a Desplegar
Antulius 0:8006a686f427 107 uint8_t punto_decimal=0; // Posición del punto decimal: 0=sin punto, 1=unidades, 2=decenas, 3=centemas 4=millares,
Antulius 0:8006a686f427 108 uint8_t cont_1ms; // Contador de milésimas de Segundo
Antulius 0:8006a686f427 109 uint8_t cont_10ms; // Contador de centésimas de Segundo
Antulius 0:8006a686f427 110 uint8_t cont_100ms; // Contador de décimas de Segundo
Antulius 0:8006a686f427 111 uint8_t cont_1s; // Contador de Segundos
Antulius 0:8006a686f427 112 uint8_t scan_rate = Scan_Time ;
Antulius 0:8006a686f427 113 uint8_t shift_rate= Shift_Time;
Antulius 0:8006a686f427 114 uint8_t display_rate=10; // Display Rate = 10ms
Antulius 0:8006a686f427 115 uint16_t counter=1250;
Antulius 0:8006a686f427 116 uint8_t i=0;
Antulius 0:8006a686f427 117 uint8_t nchar=0;
Antulius 0:8006a686f427 118 bool flag1=FALSE;
Antulius 0:8006a686f427 119 bool flag2=FALSE;
Antulius 0:8006a686f427 120 bool mode=0;
Antulius 0:8006a686f427 121 /*
Antulius 0:8006a686f427 122 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Antulius 0:8006a686f427 123 | Definición de Funciones Prototipo y Rutinas de los Vectores de Interrupción
Antulius 0:8006a686f427 124 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Antulius 0:8006a686f427 125 */
Antulius 0:8006a686f427 126 void Barrido_OnInterrupt(void);
Antulius 0:8006a686f427 127 /* END definitions */
Antulius 0:8006a686f427 128
Antulius 0:8006a686f427 129 /*
Antulius 0:8006a686f427 130 #===============================================================================
Antulius 0:8006a686f427 131 |
Antulius 0:8006a686f427 132 | P R O G R A M A P R I N C I P A L
Antulius 0:8006a686f427 133 |
Antulius 0:8006a686f427 134 #===============================================================================
Antulius 0:8006a686f427 135 */
Antulius 0:8006a686f427 136 int main()
Antulius 0:8006a686f427 137 { // Inicialización de variables, puertos e interrupciones
Antulius 0:8006a686f427 138 confSysClock(); // Configure system clock (72MHz HSE clock, 48MHz USB clock)
Antulius 0:8006a686f427 139 Barrido.attach_us(&Barrido_OnInterrupt, Rate); // Le asigna el periodo de barrido de 1ms (Rate=1000)
Antulius 0:8006a686f427 140 Terminal.baud(115200); // Se configura la velocodad de transmisión
Antulius 0:8006a686f427 141 Terminal.printf("\e[2J"); // Clear Screen
Antulius 0:8006a686f427 142 Terminal.printf(" System is Wake Up!.\n\r"); // e inicia la comunicación serial
Antulius 0:8006a686f427 143 Terminal.printf ("\t\e[1;37;41mInstituto Politecnico Nacional\e[0m\n\r");
Antulius 0:8006a686f427 144 Terminal.printf ("\e[1;37;42mESCUELA SUPERIOR DE INGENIERIA MECANICA Y ELECTRICA\e[0m\n\r\v");
Antulius 0:8006a686f427 145 Terminal.printf ("\t\e[1;34;40mBarrido \e[1;37;40mdel \e[1;32;40mDisplay \e[1;33;40mde \e[1;31;40m7 Segmentos\e[0m\n\r\v\v\e[0m");
Antulius 0:8006a686f427 146
Antulius 0:8006a686f427 147 Terminal.printf ("\nSelecciona el Modo de Operacion:\n\r");
Antulius 0:8006a686f427 148 Terminal.printf ("Modo 0 = Normal (4 Digitos)\n\r");
Antulius 0:8006a686f427 149 Terminal.printf ("Modo 1 = Corrimiento \n\r");
Antulius 0:8006a686f427 150 int opcion = getchar();
Antulius 0:8006a686f427 151 Terminal.printf ("%c \n\r",opcion);
Antulius 0:8006a686f427 152
Antulius 0:8006a686f427 153 while (TRUE) // El Lazo del Programa principal está aquí !!!
Antulius 0:8006a686f427 154 {
Antulius 0:8006a686f427 155 if (flag1==TRUE) // Está puesta la Bandera 1 ?
Antulius 0:8006a686f427 156 {
Antulius 0:8006a686f427 157 if (mode==1) // Está en modo 1? (corrimiento de mensaje)
Antulius 0:8006a686f427 158 {
Antulius 0:8006a686f427 159 Numeros[i]=Cadena[i+nchar];// Copia 4 caracteres al buffer de despliegue
Antulius 0:8006a686f427 160 if (nchar >= Size_String) nchar=0; // Restablece el contador de caractres
Antulius 0:8006a686f427 161 if (i==4) //
Antulius 0:8006a686f427 162 {
Antulius 0:8006a686f427 163 i=0; //
Antulius 0:8006a686f427 164 mode=0; //
Antulius 0:8006a686f427 165 }
Antulius 0:8006a686f427 166 }
Antulius 0:8006a686f427 167 //------------------ Barrido de los Digitos ------------------------
Antulius 0:8006a686f427 168 Anodos=Digitos[4]; // Apaga todos los Digitos (Evita fantasmas)
Antulius 0:8006a686f427 169 Catodos=Segmentos[Numeros[i]]; // Actualiza los segmentos
Antulius 0:8006a686f427 170 if (i==4-punto_decimal) Catodos=(Segmentos[Numeros[i]]& 0xFE); // Enciende el punto decimal
Antulius 0:8006a686f427 171 Anodos=Digitos[i]; // Activa el Digito en cuestión
Antulius 0:8006a686f427 172 i++; // Apunta al siguiente dígito
Antulius 0:8006a686f427 173 if (i==4) // Es el últino dígito?
Antulius 0:8006a686f427 174 {
Antulius 0:8006a686f427 175 i=0; // Reinicia el Barriodo
Antulius 0:8006a686f427 176 }
Antulius 0:8006a686f427 177 flag1=FALSE; // Apaga la Bandera 1
Antulius 0:8006a686f427 178 }
Antulius 0:8006a686f427 179
Antulius 0:8006a686f427 180 //------------------ Corrimiento de los Digitos ------------------------
Antulius 0:8006a686f427 181 if (flag2==TRUE) // Está puesta la Bandera 2?
Antulius 0:8006a686f427 182 {
Antulius 0:8006a686f427 183 shift_rate--; // Decrementa el contador de Corrimientos
Antulius 0:8006a686f427 184 if (!shift_rate) // Es Cero?
Antulius 0:8006a686f427 185 {
Antulius 0:8006a686f427 186 mode=1; // Tiempo entre desplazamientos del mensaje
Antulius 0:8006a686f427 187 shift_rate = Shift_Time;// Restablece el tiempo de los corrimientos
Antulius 0:8006a686f427 188 nchar++; // corrimiento al siguiente conjunto de de caracteres
Antulius 0:8006a686f427 189 i=0; // Restablece el barrido de los digitos
Antulius 0:8006a686f427 190 }
Antulius 0:8006a686f427 191 led_monitor=!led_monitor; // parapadeo del led_monitor
Antulius 0:8006a686f427 192 flag2=FALSE;
Antulius 0:8006a686f427 193 }
Antulius 0:8006a686f427 194 }
Antulius 0:8006a686f427 195 }
Antulius 0:8006a686f427 196 /* END main */
Antulius 0:8006a686f427 197
Antulius 0:8006a686f427 198 /*
Antulius 0:8006a686f427 199 ................................................................................
Antulius 0:8006a686f427 200 : Rutinas de los Vectores de Interrupción
Antulius 0:8006a686f427 201 ................................................................................
Antulius 0:8006a686f427 202 */
Antulius 0:8006a686f427 203 void Barrido_OnInterrupt() // Rutina de Atención al Ticker
Antulius 0:8006a686f427 204 {
Antulius 0:8006a686f427 205 cont_1ms++; // Incrmenta el contador de milisegundos
Antulius 0:8006a686f427 206 counter--; // Decrementa el contador de eventos
Antulius 0:8006a686f427 207 scan_rate--; // Decrementa el tiempo de despliege
Antulius 0:8006a686f427 208 if(!scan_rate) // Se acabo el tiempo de desplige?
Antulius 0:8006a686f427 209 {
Antulius 0:8006a686f427 210 scan_rate=Scan_Time; // Se restable el tiempo de despliegue
Antulius 0:8006a686f427 211 flag1=TRUE; // Enciende la Bandera 1
Antulius 0:8006a686f427 212 }
Antulius 0:8006a686f427 213 if (cont_1ms>=10) // Son 10ms?
Antulius 0:8006a686f427 214 {
Antulius 0:8006a686f427 215 cont_10ms++; // Incrementa el contador de decimas de ms
Antulius 0:8006a686f427 216 cont_1ms=0; // Restablece el contador de ms
Antulius 0:8006a686f427 217 }
Antulius 0:8006a686f427 218 if (cont_10ms>=10) // Son 100ms?
Antulius 0:8006a686f427 219 {
Antulius 0:8006a686f427 220 cont_100ms++;
Antulius 0:8006a686f427 221 cont_10ms=0;
Antulius 0:8006a686f427 222 }
Antulius 0:8006a686f427 223 if (cont_100ms>=10) // Son 1000ms o sea 1 seg?
Antulius 0:8006a686f427 224 {
Antulius 0:8006a686f427 225 cont_1s++;
Antulius 0:8006a686f427 226 cont_100ms=0;
Antulius 0:8006a686f427 227 }
Antulius 0:8006a686f427 228 if (cont_1s>=10) // Son 10seg?
Antulius 0:8006a686f427 229 {
Antulius 0:8006a686f427 230 cont_1s=0;
Antulius 0:8006a686f427 231 }
Antulius 0:8006a686f427 232 if (!counter)
Antulius 0:8006a686f427 233 {
Antulius 0:8006a686f427 234 counter=Counter_Time;
Antulius 0:8006a686f427 235 flag2=TRUE;
Antulius 0:8006a686f427 236 }
Antulius 0:8006a686f427 237 }
Antulius 0:8006a686f427 238 /* END Events */
Antulius 0:8006a686f427 239 /*
Antulius 0:8006a686f427 240 ________________________________________________________________________________
Antulius 0:8006a686f427 241 |
Antulius 0:8006a686f427 242 | Funciones Prototipo
Antulius 0:8006a686f427 243 |_______________________________________________________________________________
Antulius 0:8006a686f427 244 */
Antulius 0:8006a686f427 245 // Las Funciones Prototipo van aquí !
Antulius 0:8006a686f427 246
Antulius 0:8006a686f427 247
Antulius 0:8006a686f427 248 /* END program */
Antulius 0:8006a686f427 249 /*+------------------------------------------------------------------------------------
Antulius 0:8006a686f427 250 *+ Descripción del Display de 7 Segmentos de Anodos Comunes en modo multiplexado
Antulius 0:8006a686f427 251 *+-------------------------------------------------------------------------------------
Antulius 0:8006a686f427 252 *+ 13 12 11 10 9 8
Antulius 0:8006a686f427 253 *+ | | | | | |
Antulius 0:8006a686f427 254 *+ | | | | | |
Antulius 0:8006a686f427 255 *+ --------------------------------------------------
Antulius 0:8006a686f427 256 *+ | A a f A A b |
Antulius 0:8006a686f427 257 *+ | 4 3 2 |
Antulius 0:8006a686f427 258 *+ | ______________________________________________ |
Antulius 0:8006a686f427 259 *+ | | ____ ____ _____ _____ | |
Antulius 0:8006a686f427 260 *+ | | / / / / / / / / | |
Antulius 0:8006a686f427 261 *+ | | /____ / /____ / . /____ / /____ / | |
Antulius 0:8006a686f427 262 *+ | | / / / / . / / / / | |
Antulius 0:8006a686f427 263 *+ | | /____ /. /_____/ . /____ /. /____ /. | |
Antulius 0:8006a686f427 264 *+ | | | |
Antulius 0:8006a686f427 265 *+ | |______________________________________________| |
Antulius 0:8006a686f427 266 *+ | |
Antulius 0:8006a686f427 267 *+ | A |
Antulius 0:8006a686f427 268 *+ | e d p c g 1 |
Antulius 0:8006a686f427 269 *+ --------------------------------------------------
Antulius 0:8006a686f427 270 *+ | | | | | | |
Antulius 0:8006a686f427 271 *+ | | | | | | |
Antulius 0:8006a686f427 272 *+ 1 2 3 4 5 6 7
Antulius 0:8006a686f427 273 *+
Antulius 0:8006a686f427 274 *+ Display: HS410561K-D30
Antulius 0:8006a686f427 275 *+
Antulius 0:8006a686f427 276 *+
Antulius 0:8006a686f427 277 *+ 13 12 11 10 9 8
Antulius 0:8006a686f427 278 *+ | | | | | |
Antulius 0:8006a686f427 279 *+ | | | | | |
Antulius 0:8006a686f427 280 *+ --------------------------------------------------
Antulius 0:8006a686f427 281 *+ | A g f p a b |
Antulius 0:8006a686f427 282 *+ | 4 |
Antulius 0:8006a686f427 283 *+ | ______________________________________________ |
Antulius 0:8006a686f427 284 *+ | | ____ ____ _____ _____ | |
Antulius 0:8006a686f427 285 *+ | | / / / / / / / / | |
Antulius 0:8006a686f427 286 *+ | | /____ / /____ / . /____ / /____ / | |
Antulius 0:8006a686f427 287 *+ | | / / / / . / / / / | |
Antulius 0:8006a686f427 288 *+ | | /____ /. /_____/ /____ /. /____ /. | |
Antulius 0:8006a686f427 289 *+ | | | |
Antulius 0:8006a686f427 290 *+ | |______________________________________________| |
Antulius 0:8006a686f427 291 *+ | |
Antulius 0:8006a686f427 292 *+ | A A A |
Antulius 0:8006a686f427 293 *+ | e 3 2 c d 1 |
Antulius 0:8006a686f427 294 *+ --------------------------------------------------
Antulius 0:8006a686f427 295 *+ | | | | | | |
Antulius 0:8006a686f427 296 *+ | | | | | | |
Antulius 0:8006a686f427 297 *+ 1 2 3 4 5 6 7
Antulius 0:8006a686f427 298 *+
Antulius 0:8006a686f427 299 *+ Display: BQ-M544RE
Antulius 0:8006a686f427 300 *+
Antulius 0:8006a686f427 301 *+
Antulius 0:8006a686f427 302 *+ 16 15 14 13 11
Antulius 0:8006a686f427 303 *+ | | | | |
Antulius 0:8006a686f427 304 *+ | | | | |
Antulius 0:8006a686f427 305 *+ --------------------------------------------------
Antulius 0:8006a686f427 306 *+ | b g a c f |
Antulius 0:8006a686f427 307 *+ | |
Antulius 0:8006a686f427 308 *+ | ______________________________________________ |
Antulius 0:8006a686f427 309 *+ | | ____ ____ _____ . _____ | |
Antulius 0:8006a686f427 310 *+ | | / / / / / / / / | |
Antulius 0:8006a686f427 311 *+ | | /____ / /____ / . /____ / /____ / | |
Antulius 0:8006a686f427 312 *+ | | / / / / . / / / / | |
Antulius 0:8006a686f427 313 *+ | | /____ /. /_____/ . /____ /. /____ /. | |
Antulius 0:8006a686f427 314 *+ | | | |
Antulius 0:8006a686f427 315 *+ | |______________________________________________| |
Antulius 0:8006a686f427 316 *+ | |
Antulius 0:8006a686f427 317 *+ | A A A A A |
Antulius 0:8006a686f427 318 *+ | 4 3 3 p e 2 p 1 |
Antulius 0:8006a686f427 319 *+ --------------------------------------------------
Antulius 0:8006a686f427 320 *+ | | | | | | | |
Antulius 0:8006a686f427 321 *+ | | | | | | | |
Antulius 0:8006a686f427 322 *+ 1 2 3 4 5 6 7 8
Antulius 0:8006a686f427 323 *+
Antulius 0:8006a686f427 324 *+ Display: KEM-3942BSR
Antulius 0:8006a686f427 325 *+
Antulius 0:8006a686f427 326 +*
Antulius 0:8006a686f427 327 *+
Antulius 0:8006a686f427 328 *+ 12 11 10 9 8 7
Antulius 0:8006a686f427 329 *+ | | | | | |
Antulius 0:8006a686f427 330 *+ | | | | | |
Antulius 0:8006a686f427 331 *+ --------------------------------------------------
Antulius 0:8006a686f427 332 *+ | A a f A A b |
Antulius 0:8006a686f427 333 *+ | 4 3 2 |
Antulius 0:8006a686f427 334 *+ | ______________________________________________ |
Antulius 0:8006a686f427 335 *+ | | ____ ____ _____ _____ | |
Antulius 0:8006a686f427 336 *+ | | / / / / / / / / | |
Antulius 0:8006a686f427 337 *+ | | /____ / /____ / . /____ / /____ / | |
Antulius 0:8006a686f427 338 *+ | | / / / / . / / / / | |
Antulius 0:8006a686f427 339 *+ | | /____ /. /_____/ . /____ /. /____ /. | |
Antulius 0:8006a686f427 340 *+ | | | |
Antulius 0:8006a686f427 341 *+ | |______________________________________________| |
Antulius 0:8006a686f427 342 *+ | |
Antulius 0:8006a686f427 343 *+ | A |
Antulius 0:8006a686f427 344 *+ | e d p c g 1 |
Antulius 0:8006a686f427 345 *+ --------------------------------------------------
Antulius 0:8006a686f427 346 *+ | | | | | |
Antulius 0:8006a686f427 347 *+ | | | | | |
Antulius 0:8006a686f427 348 *+ 1 2 3 4 5 6
Antulius 0:8006a686f427 349 *+
Antulius 0:8006a686f427 350 *+ Display: FYQ-2841BH
Antulius 0:8006a686f427 351 *+
Antulius 0:8006a686f427 352 *+
Antulius 0:8006a686f427 353 *+ PB_15 PB_14 PB_13 PB_12
Antulius 0:8006a686f427 354 *+ A4 A3 A2 A1
Antulius 0:8006a686f427 355 *+ Mill Cent Dec Uni
Antulius 0:8006a686f427 356 *+
Antulius 0:8006a686f427 357 *+ STM32-F103C8 PB_4 PB_3 PA_15 PA_12 PA_11 PA_10 PA_9 PA_8 # Hex Offset
Antulius 0:8006a686f427 358 *+ a
Antulius 0:8006a686f427 359 *+ ______ g f a b c d e p
Antulius 0:8006a686f427 360 *+ / / 1 0 0 0 1 0 0 0 0 0x81 0
Antulius 0:8006a686f427 361 *+ f / g / b 1 1 0 1 1 1 1 0 1 0xE7 1
Antulius 0:8006a686f427 362 *+ /_____/ 1 0 1 1 0 1 0 0 2 0x49 2
Antulius 0:8006a686f427 363 *+ / / 1 0 0 1 0 1 0 0 3 0x43 3
Antulius 0:8006a686f427 364 *+ e / / c 1 1 0 1 0 0 1 0 4 0x27 4
Antulius 0:8006a686f427 365 *+ /_____/ . 1 0 0 1 0 0 0 1 5 0x13 5
Antulius 0:8006a686f427 366 *+ d p 1 0 0 0 0 0 0 1 6 0x11 6
Antulius 0:8006a686f427 367 *+ 1 1 0 1 1 1 0 0 7 0xC7 7
Antulius 0:8006a686f427 368 *+ 1 0 0 0 0 0 0 0 8 0x01 8
Antulius 0:8006a686f427 369 *+ 1 0 0 1 0 0 0 0 9 0x03 9
Antulius 0:8006a686f427 370 *+ 1 1 0 0 0 0 0 0 A 0x05 10
Antulius 0:8006a686f427 371 *+ 1 0 0 0 0 0 1 1 b 0x31 11
Antulius 0:8006a686f427 372 *+ 1 0 1 0 1 0 0 1 C 0x99 12
Antulius 0:8006a686f427 373 *+ 1 0 0 0 0 1 1 0 d 0x61 13
Antulius 0:8006a686f427 374 *+ 1 0 1 0 0 0 0 1 E 0x19 14
Antulius 0:8006a686f427 375 *+ 1 1 1 0 0 0 0 1 f 0x1D 15
Antulius 0:8006a686f427 376 *+ 1 0 0 0 1 0 0 1 G 0x91 16
Antulius 0:8006a686f427 377 *+ 1 1 0 0 0 0 1 1 h 0x35 17
Antulius 0:8006a686f427 378 *+ 1 1 0 1 1 1 1 1 i 0xBD 18
Antulius 0:8006a686f427 379 *+ 1 0 0 0 1 1 1 0 J 0xB3 19
Antulius 0:8006a686f427 380 *+ 1 0 1 0 0 0 1 0 k 0x2D 20
Antulius 0:8006a686f427 381 *+ 1 0 1 0 1 0 1 1 L 0xB9 21
Antulius 0:8006a686f427 382 *+ 1 1 0 0 1 0 0 0 M 0x85 22
Antulius 0:8006a686f427 383 *+ 1 1 0 0 0 1 1 1 n 0x75 23
Antulius 0:8006a686f427 384 *+ 1 0 0 0 0 1 1 1 o 0x71 24
Antulius 0:8006a686f427 385 *+ 1 1 1 0 0 0 0 0 P 0x0D 25
Antulius 0:8006a686f427 386 *+ 1 1 0 1 0 0 0 0 q 0x07 26
Antulius 0:8006a686f427 387 *+ 1 1 1 0 0 1 1 1 r 0x3D 27
Antulius 0:8006a686f427 388 *+ 1 0 0 1 0 0 0 1 s 0x13 28
Antulius 0:8006a686f427 389 *+ 1 0 1 0 0 0 1 1 t 0x39 29
Antulius 0:8006a686f427 390 *+ 1 0 0 0 1 1 1 1 u 0xF1 30
Antulius 0:8006a686f427 391 *+ 1 0 0 0 1 0 1 1 V 0xE1 31
Antulius 0:8006a686f427 392 *+ 1 0 0 0 1 0 1 0 w 0xA1 32
Antulius 0:8006a686f427 393 *+ 1 1 0 0 1 0 1 0 X 0x25 33
Antulius 0:8006a686f427 394 *+ 1 0 0 1 0 0 1 0 y 0x37 34
Antulius 0:8006a686f427 395 *+ 1 0 1 0 1 1 0 0 Z 0x49 35
Antulius 0:8006a686f427 396 *+ 1 0 0 0 0 1 0 0 a 0x84 36
Antulius 0:8006a686f427 397 *+ 1 0 1 0 0 0 0 0 e 0xA0 37
Antulius 0:8006a686f427 398 *+ 1 1 1 1 0 0 0 1 + c 0xF1 38
Antulius 0:8006a686f427 399 *+ 1 1 1 1 0 1 0 0 +/c 0xF4 39
Antulius 0:8006a686f427 400 *+ 1 0 1 0 0 1 1 1 c 0xA7 40
Antulius 0:8006a686f427 401 *+ 1 0 0 1 0 1 1 1 /c 0x97 41
Antulius 0:8006a686f427 402 *+ 1 1 1 1 0 0 1 0 + u 0xF2 42
Antulius 0:8006a686f427 403 *+ 1 1 1 1 1 0 0 0 + n 0xF8 43
Antulius 0:8006a686f427 404 *+ 1 0 1 0 1 0 0 1 [ 0xA9 44
Antulius 0:8006a686f427 405 *+ 1 0 0 1 1 1 0 0 ] 0x9C 45
Antulius 0:8006a686f427 406 *+ 1 1 1 1 0 0 0 0 ° 0xF0 46
Antulius 0:8006a686f427 407 *+ 1 1 1 1 1 1 0 0 ¬ 0xFC 47
Antulius 0:8006a686f427 408 *+ 1 1 1 1 0 1 1 0 + > 0xF6 48
Antulius 0:8006a686f427 409 *+ 1 1 1 0 0 1 1 1 ^ 0xE7 49
Antulius 0:8006a686f427 410 *+ 1 0 1 0 1 1 1 1 / < 0xAF 50
Antulius 0:8006a686f427 411 *+ 1 0 0 1 1 1 1 1 / v 0x9F 51
Antulius 0:8006a686f427 412 *+ 1 1 0 1 0 1 1 1 > 0xD7 52
Antulius 0:8006a686f427 413 *+ 1 1 1 1 0 0 1 1 v 0xF3 53
Antulius 0:8006a686f427 414 *+ 1 1 1 1 1 0 0 1 < 0xF9 54
Antulius 0:8006a686f427 415 *+ 1 1 1 1 1 1 0 1 / _ 0xBF 55
Antulius 0:8006a686f427 416 *+ 1 1 1 1 0 1 1 1 - 0xF7 56
Antulius 0:8006a686f427 417 *+ 1 0 1 1 1 1 1 1 _ 0xFD 57
Antulius 0:8006a686f427 418 *+ 1 1 1 1 0 1 0 1 = 0xF5 58
Antulius 0:8006a686f427 419 *+ 1 0 1 1 0 1 1 1 / = 0xB7 59
Antulius 0:8006a686f427 420 *+ 1 0 1 1 0 1 0 1 == 0xB5 60
Antulius 0:8006a686f427 421 *+ 1 0 1 1 1 1 0 1 _¬ 0xBD 61
Antulius 0:8006a686f427 422 *+ 1 1 0 0 1 1 1 1 ii 0xCF 62
Antulius 0:8006a686f427 423 *+ 1 1 1 1 1 0 1 0 # 0xFA 63
Antulius 0:8006a686f427 424 *+ 1 0 0 1 1 1 1 0 j 0x9E 64
Antulius 0:8006a686f427 425 *+ 1 1 0 1 1 1 0 0 /j 0xDC 65
Antulius 0:8006a686f427 426 *+ 1 1 1 0 1 0 0 1 - j 0xE9 66
Antulius 0:8006a686f427 427 *+ 1 0 1 0 1 0 1 1 -/j 0xAB 67
Antulius 0:8006a686f427 428 *+ 1 0 0 0 1 1 1 0 - J 0x8E 68
Antulius 0:8006a686f427 429 *+ 1 1 0 1 1 0 0 0 -/J 0xD8 69
Antulius 0:8006a686f427 430 *+ 1 1 1 0 1 0 1 1 | 0xEB 70
Antulius 0:8006a686f427 431 *+ 1 1 0 0 1 0 1 0 || 0xCA 71
Antulius 0:8006a686f427 432 *+ 1 1 0 1 0 1 1 0 + 0xD6 72
Antulius 0:8006a686f427 433 *+ 1 1 1 0 0 0 1 1 /+ 0xE3 73
Antulius 0:8006a686f427 434 *+ 1 0 0 1 1 0 1 1 espacio 0xFF 74
Antulius 0:8006a686f427 435 *+
Antulius 0:8006a686f427 436 *+ Nota: Cada dígito se activa al hacer la señal A correspondiente en "alto"
Antulius 0:8006a686f427 437 *+ y enviar las señales de los segmentos que se desean encender en "bajo"
Antulius 0:8006a686f427 438 *+
Antulius 0:8006a686f427 439 *+---------------------------------------------------------------------------------------- */
Antulius 0:8006a686f427 440 /* END documentation */