Использование этой библиотеки значительно упрощает работу с семисегментным индикатором. Библиотека написана под четырехразрядный семисегментный индикатор с общим анодом или катодом. Она позволяет выводить на дисплей не только цифры, но и буквы, текущее время, бегущую строку, менять яркость свечения индикатора. Далее рассмотрим функции этой библиотеки(скачать файлы display.c и display.h можно внизу статьи).
display_init(void); - инициализация дисплея
set_brightness(uint8_t b); - установка яркости от 0 до 100
shift_in(char c); - сдвиг символа на одну позицию справа-налево
set_char_at(char c, uint8_t offset); - вывод символа в определенное знакоместо
Например: set_char_at('A', 0); // вывод символа А в первое знакоместо
set_char_at(2, 2); // вывод цифры 2 в третье знакоместо
set_segments_at(uint8_t segments, uint8_t offset); - вывод сегмента в определенное знакоместо
Например: set_segments_at(2, 1); // вывод сегмента "b" во второе знакоместо
shift_in_segments(uint8_t segments); - сдвиг сегмента на одну позицию справа-налево
set_number(uint16_t num); - вывод четырехразрядной переменной
clear_screen(void); - очистить дисплей
set_time(uint8_t hour, uint8_t min, uint8_t sec); - вывод времени в формате "ЧЧ.ММ"
set_number_4(uint8_t num_0, uint8_t num_1, uint8_t num_2, uint8_t num_3, uint8_t offset); - вывод значений поразрядно, вывод точки в позицию 1..4, 0 - неактивна
Для создания своего проекта как обычно добавляем к нему два файла display.c и display.h. Принцип работы библиотеки рассмотрим на примере часов. Используем для этого микроконтроллер atmega8, который тактируется от внешнего кварца частотой 8 МГц. Внешний кварц выбран для более точного хода часов. Сегменты индикатора подключаем к порту D, кстати в заголовочном файле display.h можно изменить конфигурацию подключения по своему желанию, если например, на печатной плате надо оптимизировать разводку дорожек. Общие аноды(катоды) подключаются к выводам PB3-PB0. Настройка часов осуществляется с помощью двух кнопок "Часы+" и "Минуты+", при нажатии на которые увеличиваются часы и минуты соответственно. При нажатии на обе кнопки изменяется яркость дисплея.

В нашей программе используются два таймера Т0 и Т1. Восьмибитный таймер Т0 используется для динамической индикации, шестнадцатибитный таймер Т1 используется для создания интервала в 1 секунду, он используется для подсчета времени. Как только наступает прерывание по совпадению Т1 переменная "second" увеличивается на 1 секунду, если "second" будет больше 60, переменная "minute" увеличится на 1 минуту, если переменная "minute" будет больше 60, переменная "hour" увеличится на 1 час, и т.д по кругу. Полный текст программы представлен ниже:
// Использование библиотеки для работы с семисегментным индикатором
#include <avr/io.h>
#include <util/delay.h>
#include <avr/interrupt.h>
#include "display.h"
volatile unsigned char second, minute, hour, level;
// Обработчик прерывания по совпадению Т1
ISR(TIMER1_COMPA_vect)
{
second++; // Увеличиваем секунды
if(second == 60)
{
second = 0;
minute++; // Увеличиваем минуты
if(minute == 60)
{
minute = 0;
hour++; // Увеличиваем часы
if(hour == 24) hour = 0;
}
}
set_time(hour,minute,second); // Выводим на дисплей
}
int main(void)
{
hour = 12; // Начальная установка времени
minute = 0;
second = 0;
// Порты ввода/вывода
DDRB |= (0 << PB5)|(0 << PB4);
PORTB |= (1 << PB5)|(1 << PB4);
// Настройка Т1
TCCR1B |= (1 << WGM12)|(1 << CS12); // 8MHz/256/(1+31249)=1Hz
OCR1A = 31249;
sei(); // Глобально разрешам прерывания
set_brightness(80); // Начальная установка яркости дисплея
display_init(); // Инициализация дисплея
// Выводим бегущую строку "test display"
shift_in('t');
_delay_ms(100);
shift_in('E');
_delay_ms(100);
shift_in('s');
_delay_ms(100);
shift_in('t');
_delay_ms(100);
shift_in(' ');
_delay_ms(100);
shift_in('d');
_delay_ms(100);
shift_in('i');
_delay_ms(100);
shift_in('s');
_delay_ms(100);
shift_in('p');
_delay_ms(100);
shift_in('L');
_delay_ms(100);
shift_in('a');
_delay_ms(100);
shift_in('y');
_delay_ms(100);
shift_in(' ');
_delay_ms(100);
shift_in(' ');
_delay_ms(100);
shift_in(' ');
_delay_ms(100);
clear_screen();
_delay_ms(100);
TIMSK |= (1 << OCIE1A); // Разрешаем прерывание по совпадению Т1
while(1)
{
unsigned char i, dr;
// Если кнопка Часы+ и Минуты+ нажаты увеличиваем яркость
if((PINB&(1 << PB4)) == 0 && (PINB&(1 << PB5)) == 0)
{
dr = 0;
// Программный антидребезг контактов
for(i = 0; i < 10; i++)
{
_delay_ms(5);
if((PINB&(1 << PB4)) == 0 && (PINB&(1 << PB5)) == 0)
dr++;
}
if(dr > 5)
{
if(level != 99)
level++; // Увеличиваем яркость
else level = 0;
set_brightness(level);
}
}
// Если кнопка Часы+ нажата увеличиваем часы
if((PINB&(1 << PB4)) == 0 && PINB&(1 << PB5))
{
dr=0;
// Программный антидребезг контактов
for(i = 0; i < 10; i++)
{
_delay_ms(5);
if((PINB&(1 << PB4)) == 0)
dr++;
}
if(dr > 5)
{
if(hour != 23) hour++; // Увеличиваем часы
else hour = 0;
set_time(hour,minute,second); // Выводим на дисплей
}
}
// Если кнопка Минуты+ нажата увеличиваем минуты
if((PINB&(1 << PB5))==0 && PINB&(1 << PB4))
{
dr=0;
// Программный антидребезг контактов
for(i = 0; i < 10; i++)
{
_delay_ms(5);
if((PINB&(1 << PB5)) == 0)
dr++;
}
if (dr > 5)
{
if(minute != 59) minute++; // Увеличиваем минуты
else minute = 0;
set_time(hour,minute,second); // Выводим на дисплей
}
}
}
}
Обсуждение статьи на форуме
| Архив для статьи "Использование библиотеки для работы с семисегментным индикатором. Делаем простые часы." | |
| Описание: Проект AVRStudio и Proteus | |
| Размер файла: 64.41 KB Количество загрузок: 4 843 | Скачать |


Комментарии
Здравствуйте. Добавил в библиотеку функцию set_number_4, через нее вывел температуру, пример в файлах к этой статье