Introduction: TIMER WITH THE ATTINY85

About: designer of circuits and professional electronic projects www.pcbway.com

HOY APRENDEREMOS A REALIZAR UN TEMPORIZADOR DE FUNCIONAMIENTO CON EL MICROCONTROLADOR ATTINY85

Supplies

Step 1: SCHEMATIC DIAGRAM

HERE WE WILL SEE THE SCHEMATIC DIAGRAM AND ALL THE VALUES OF THE ELECTRONIC COMPONENTS USED FOR OUR TIMER PROJECT.

Step 2: 74HC595

INFO

The 74HC595 register allows converting data from serial to parallel format. It is an ideal chip to expand the digital outputs of our Arduino/Pic, 3 Arduino pins can easily handle more than 500 outputs. The 74HC595 is used in the construction of LED Matrix/Cubes, Relay management and more.


The 74HC595 internally has a shift register, a latch register, and tri-state outputs. The shift and storage registers have separate clocks. It has one serial input, eight parallel type outputs (8 bit) and one serial output (Q7S) to use registers in cascade and thus further expand the number of parallel outputs.


TECHNICAL SPECIFICATIONS

Chip: 74HC595

CMOS technology

Compatible with TTL voltages

Operating Voltage: 3.3V - 5V

16 pin DIP type packaging

Offset Frequency (max): 100 MHz

Step 3: BOOTLOADER ATTINY85

Ok, we have to burn a bootloader to the chi adn then uplaod the code. For both those steps we need the connections below to an Arduino. In my case I will use Arduino UNO. So, make the connections as below between the Arduino SPI port and the PCB. We will sue the Arduino as ISP to uplaod codes.


Step 4: Install ATtiny Boards

Run your Arduino IDE. We need to install the ATtiny85 boards in case that you don't already have that. To install the boards, copy the link below. Go to Ardduino IDE, to File -> Preferences -> Paste the link in the "Additional Boards Manager URLs". If you already have another link ther, add a comm "," first and then paste the new link. Save and close preferences. Now go to Tools -> Board -> Boards Manager. In this manager search for ATtiny adn install the attiny boards. Now, if you go on tool -> board, you should see the ATtiny boards as well.


https://raw.githubusercontent.com/damellis/attiny/ide-1.6.x-boards-manager/package_damellis_attiny_index.json

Step 5: Arduino As ISP

In order to use the Arduino as an ISP programmer, we need to uplaod a code to it so for taht, go to Examples -> ArduinoISP -> ArduinoISP and open that example code. Then make sure yous elect the type of board for your Arduino, in my case, Arduino UNO. Select the com and leave the default programmer as "AVRISP mkII". Connect the USB, select the COM and uplaod the code to the Arduino UNO.

Step 6: Bootloader Burn

Ok, now the Arduino has the ISP code so it will act as a ISP programmer. Now, let's butn the bootloader. Go to Tools -> Board and selectt the ATtiny25/45/85 type of board. Then, once that is selected, go to Tools -> Processor -> And select the ATtiny85. Then go to Clock -> and select the internal 8MHz one so we will burn that bootlaoder. Go to Tools -> Programmer and make sure you now change the normal programmer from "AVRISP mkII" to "Arduino as ISP". Finally, amke sure the Arduino UNO is connected to the PCB to the ISP port and go to Tools -> Burn Bootloader. The Arduino Rx/Tx LEDs will blink and after a while you will get the bootloader burn complete on the screen.

Step 7: CODE ARDUINO

int clockpin = 2; //Cuando ay que leer los bit      SH
int data = 1; //Envio datos DS
int latch = 0; //indica pin de salida en el chip ST


// no cambiar el const int
const int left_sen = 4 ; // pin 2 como entrada para el sensor izquierdo
const int right_sen = 3; // pin 3 como entrada para el sensor derecho


//VARIABLES PARA EL CONTADOR ASCENDIENTE
// estas variables si puede ser cambiado
int contador = 0;
int contadorU = 0;
int contadorD = 0;
int contadorC = 0;
int contadorM = 0;
int estado_left_sen = 0; // estado del pulsado actual
int lastButtonState_left = 1; // estado del pulsado anterior






boolean start = false;
boolean start1 = false;
boolean ena_D = false;
boolean ena_C = false;
boolean ok = false;


unsigned long time;
float tiempo = 1000;
unsigned long t = 0;


//VARIABLES PARA EL CONTADOR DESCENDIENTE
// estas variables si puede ser cambiado


int estado_right_sen = 0; // estado del pulsado actual
int lastButtonState_right = 1; // estado del pulsado anterior


//Aqui esta el array que contiene todos los UNDs para nuestro display
//El display tiene las conexiones alcontrario ell pin 8 del 74hc595 es el primer dijito binario


const int NUM[] = { // segmentos
191, //Numero 0 en binario es : 10111111
134, //Numero 1 en binario es : 10000110
219, //Numero 2 en binario es : 11011011
207, //Numero 3 en binario es : 11001111
230, //Numero 4 en binario es : 11100110
237, //Numero 5 en binario es : 11101101
253, //Numero 6 en binario es : 11111101
135, //Numero 7 en binario es : 10000111
255, //Numero 8 en binario es : 11111111
239, //Numero 9 en binario es : 11101111
191, //Numero 0 en binario es : 10111111




14, //Numero 7 en binario es : 00001110
13, //Numero 8 en binario es : 00001101
11, //Numero 9 en binario es : 00001011
7, //Numero 0 en binario es : 00000111


46, //Numero 7 en binario es : 00101110
45, //Numero 8 en binario es : 00101101
43, //Numero 9 en binario es : 00101011
39, //Numero 0 en binario es : 00100111


};


void setup() {


pinMode(left_sen, INPUT);
pinMode(right_sen, INPUT);


pinMode(latch, OUTPUT);
pinMode(clockpin, OUTPUT);
pinMode(data, OUTPUT);


}
void loop()
{
if (start == false) {
digitalWrite(latch, LOW);
shiftOut(data, clockpin, MSBFIRST, NUM[11]); // lee el arreglo y pasa cada NUM a lectura binaria
shiftOut(data, clockpin, MSBFIRST, NUM[0]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);
digitalWrite(latch, LOW);
shiftOut(data, clockpin, MSBFIRST, NUM[12]); // lee el arreglo y pasa cada NUM a lectura binaria
shiftOut(data, clockpin, MSBFIRST, NUM[0]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);


digitalWrite(latch, LOW);
shiftOut(data, clockpin, MSBFIRST, NUM[13]); // lee el arreglo y pasa cada NUM a lectura binaria
shiftOut(data, clockpin, MSBFIRST, NUM[0]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);


digitalWrite(latch, LOW);
shiftOut(data, clockpin, MSBFIRST, NUM[14]); // lee el arreglo y pasa cada NUM a lectura binaria
shiftOut(data, clockpin, MSBFIRST, NUM[0]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);
}


estado_left_sen = digitalRead(left_sen);
estado_right_sen = digitalRead(right_sen);




if (estado_left_sen != lastButtonState_left) {
if (estado_left_sen == HIGH) {
start = true;
start1 = false;
ok = false;


if (contador <= 5940) {


if (contadorU >= 10) {
contadorU = 0;
}
if (contadorU >= 9) {
contadorD++;
}
if (contadorD >= 6) {
contadorD = 0;
contadorC++;
}
if (contadorC >= 10) {
contadorC = 0;
contadorM++;
}
if (contadorM >= 6) {
contadorM = 0;
}
contador++;
contadorU++;


}


}
}
lastButtonState_left = estado_left_sen;


if (estado_right_sen != lastButtonState_right ) {
if (estado_right_sen == HIGH) {
start1 = true;
//start = false;
ok = true;
}
}
lastButtonState_right = estado_right_sen;


if (start1 == true) {
time = millis();
if (time - t > tiempo) {
t = time;
if (contador > 0) {
contador--;
contadorU--;


if (contadorU == 0) {


contadorU = 10;


}


if (contadorU == 9) {
if (contadorD > 0) {
contadorD--;
}
}
else if (contadorD == 0 && contadorU == 10) {
ena_D = true;
}


if ((ena_D == true) && (contadorU == 9)) {


if (contadorC > 0) {
contadorD = 5;
ena_D = false;
contadorC--;
}
}
if (contadorC == 0 && contadorD == 0 && contadorU == 10) {
ena_C = true;
}
if (ena_C == true && contadorD == 5 && contadorU == 9) {
if (contadorM > 0) {
contadorC = 9 ;
ena_C = false;
contadorM--;
}


}
}
}
cont ();
}
if (contadorU == 10 && contadorD == 0 && contadorC == 0 && contadorM == 0) {
ok = false;
}
if (start == true) {
cont ();
}




}
void cont() {
digitalWrite(latch, LOW);
if (ok == false && contadorU >= 0 && contadorD >= 0 && contadorC >= 0 && contadorM >= 0) {
shiftOut(data, clockpin, MSBFIRST, NUM[11]); // lee el arreglo y pasa cada NUM a lectura binaria
}
else if (ok == true && (contadorU > 0 || contadorD > 0 || contadorC > 0 || contadorM > 0)) {
shiftOut(data, clockpin, MSBFIRST, NUM[15]); // lee el arreglo y pasa cada NUM a lectura binaria
}
shiftOut(data, clockpin, MSBFIRST, NUM[contadorM]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);


digitalWrite(latch, LOW);
if (ok == false && contadorU >= 0 && contadorD >= 0 && contadorC >= 0 && contadorM >= 0) {
shiftOut(data, clockpin, MSBFIRST, NUM[12]); // lee el arreglo y pasa cada NUM a lectura binaria
}
else if (ok == true && (contadorU > 0 || contadorD > 0 || contadorC > 0 || contadorM > 0)) {
shiftOut(data, clockpin, MSBFIRST, NUM[16]); // lee el arreglo y pasa cada NUM a lectura binaria
}
shiftOut(data, clockpin, MSBFIRST, NUM[contadorC]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);


digitalWrite(latch, LOW);
if (ok == false && contadorU >= 0 && contadorD >= 0 && contadorC >= 0 && contadorM >= 0) {
shiftOut(data, clockpin, MSBFIRST, NUM[13]); // lee el arreglo y pasa cada NUM a lectura binaria
}
else if (ok == true && (contadorU > 0 || contadorD > 0 || contadorC > 0 || contadorM > 0)) {
shiftOut(data, clockpin, MSBFIRST, NUM[17]); // lee el arreglo y pasa cada NUM a lectura binaria
}
shiftOut(data, clockpin, MSBFIRST, NUM[contadorD]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);


digitalWrite(latch, LOW);
if (ok == false && contadorU >= 0 && contadorD >= 0 && contadorC >= 0 && contadorM >= 0) {
shiftOut(data, clockpin, MSBFIRST, NUM[14]); // lee el arreglo y pasa cada NUM a lectura binaria
}
else if (ok == true && (contadorU > 0 || contadorD > 0 || contadorC > 0 || contadorM > 0)) {
shiftOut(data, clockpin, MSBFIRST, NUM[18]); // lee el arreglo y pasa cada NUM a lectura binaria
}
shiftOut(data, clockpin, MSBFIRST, NUM[contadorU]); // lee el arreglo y pasa cada NUM a lectura binaria
digitalWrite(latch, HIGH);
delayMicroseconds(1);
}

Step 8: ELECTRONIC COMPONENTS

  • 2 DIODOS 1N5819 SMD
  • 3 CAP. 100NF 1206
  • 2 BT3904 TRANSISTOR NPN SMD
  • 3 RESISTOR 1K 1206 SMD
  • 4 RESISTOR 10K 1206 SMD
  • 8 RESISTOR 220 ohm 1206 SMD
  • 1 DIODO 1N4148 SMD
  • 1 DIODO LED 1206 RED
  • 3 BUTTON 4 PINS
  • 4 DISPLAY CATODO COMUN
  • 1 BUZZER 5VDC
  • 2 CI 74HC595
  • 1 RELE 5VDC
  • 1 TERMINAL BLUE 2 PIN
  • 1 TERMINAL BLUE 3 PIN
  • 1 PCB

Step 9: EASYEDA

Once the project is finished with all the respective tests, we carry out the PCB design and we will obtain the routed tracks and the 3D image of how our finished PCB would look.

Step 10: PCBWay

PCBWAY has 10 years in the electronics industry manufacturing professional PCBs, assembling PCBs managing to satisfy the demands of all parts of the world, in addition to meeting the highest quality and delivery time standards. PCBWAY allows the manufacture of your PCBs from 5 units.

This project was carried out thanks to PCBWAY, a company dedicated to the manufacture of prototypes and professional PCBs, in addition to offering you a ready assembly service with all the components in your PCBS, complying with the established quality and delivery time standards.

We thank PCBWAY, a leading company for manufacturing and assembling professional PCBs with the highest quality, PCBWAY has fair reasonable prices, punctual shipping time and 24-hour customer service, it also offers you the option of quoting all its services in his web page. Do not think twice and start manufacturing your professional PCBs from 5 units safely.

10pcbs at $5 order them here www.pcbway.com

We thank PCBWAY for the professional pcb they provide us for this project.

GERBER PCB:

https://mega.nz/file/eRwA1Q5D#6HnrcAPaUwlRHEnMkTAI0cX6lRa_7LEuygl4qB_5niA