timer1 и timer2 сейчас переменные не работают, красная лампочка зажигается и все, как будто той части нет, там где timer2 мигает само по себе по timerADC (где горит и не горит по времени одинаково)
LED Driver на Attiny13A
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
Карбофос, это я просто копировала с шаблона с коммами, потом не убрала под свой вариант.
timer1 и timer2 сейчас переменные не работают, красная лампочка зажигается и все, как будто той части нет, там где timer2 мигает само по себе по timerADC (где горит и не горит по времени одинаково)
timer1 и timer2 сейчас переменные не работают, красная лампочка зажигается и все, как будто той части нет, там где timer2 мигает само по себе по timerADC (где горит и не горит по времени одинаково)
- Реклама
В этом фрагменте вы сбрасываете счетчики в 0.
Поэтому, я предложил вам переписать эту функцию, т.к. логика в ваших сравнениях отсутствует.
Поэтому, я предложил вам переписать эту функцию, т.к. логика в ваших сравнениях отсутствует.
Код: Выделить всё
if ((adc_raw <= 207)&&(adc_raw > 183))
{
if (countMode == 1)
{
PORTB = 0b00000111;
timer1 = 0;
timer2 = 0;
}
if (countMode == 0)
{
PORTB = 0b00000101;
timer1 = 0;
timer2 = 0;
}
}
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
Карбофос, допустим, а разве они в следующих условиях не набирают заново счет?
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
Карбофос, ну да, где условие ниже 183 зажигает лампочку красную, но на этом останавливается и не переходит к таймерному условию
- Реклама
183 соотв-ет 3.14 вольт.
Если это LiIon - то аккумулятор разряжен.
Опять-же, если говорим про LiIon, на 3.7 вольт значение будет ~215, 3.3 вольт ~192.
Если это LiIon - то аккумулятор разряжен.
Опять-же, если говорим про LiIon, на 3.7 вольт значение будет ~215, 3.3 вольт ~192.
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
Карбофос, это я знаю, пока отметила примерные значения, чтоб хоть как-то запустить, а потом уже поправлю
Да уж. 
[uquote="Bondosha",url="/forum/viewtopic.php?p=4087901#p4087901"]timer1 и timer2 сейчас переменные не работают, красная лампочка зажигается и все, как будто той части нет, там где timer2 мигает само по себе по timerADC[/uquote]
timer2 у вас нигде не используется.
[uquote="Bondosha",url="/forum/viewtopic.php?p=4080432#p4080432"]2) При полунажатии на кнопку должен переключиться режим, экономящий яркость - 1-ки подаем на PB0 и PB1[/uquote]
Объяcните, как эта кнопка выглядит, как она включена, и что при ее "полунажатии" происходит. Фото.
[uquote="Bondosha",url="/forum/viewtopic.php?p=4087901#p4087901"]timer1 и timer2 сейчас переменные не работают, красная лампочка зажигается и все, как будто той части нет, там где timer2 мигает само по себе по timerADC[/uquote]
timer2 у вас нигде не используется.
[uquote="Bondosha",url="/forum/viewtopic.php?p=4080432#p4080432"]2) При полунажатии на кнопку должен переключиться режим, экономящий яркость - 1-ки подаем на PB0 и PB1[/uquote]
Объяcните, как эта кнопка выглядит, как она включена, и что при ее "полунажатии" происходит. Фото.
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
Карбофос, там timer2 вместо timerADC в куске после 183, записала там ADC, чтоб показать, что работает только с ним.
кнопка KAN-15A, замыкается полностью при нажатии, при полунажатии контакты на пару секунд размыкаются. кнопка только для включения и переключения яркости, при нажатии просто единичка на PB1, где дополнительный резистор стоит, который уменьшает свечение, фото этого не знаю зачем. Подключена к верхнему резистору на 30кОм
кнопка KAN-15A, замыкается полностью при нажатии, при полунажатии контакты на пару секунд размыкаются. кнопка только для включения и переключения яркости, при нажатии просто единичка на PB1, где дополнительный резистор стоит, который уменьшает свечение, фото этого не знаю зачем. Подключена к верхнему резистору на 30кОм
Bondosha, тебе ж Карбофос показал правильную конструкцию сравнения adc_raw, что бы сама не путалась и других не путала
ohmycode!
primuss3.com
primuss3.com
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
slav0n, даже с этой правильной конструкцией не работает как надо, представь себе
да как же в нем можно разобраться, если оно такое непричесанное.
предлагаю расческу - http://format.krzaq.cc/
предлагаю расческу - http://format.krzaq.cc/
ohmycode!
primuss3.com
primuss3.com
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
Пока вот такой конечный вариант, и опять помеха на уровне 2.3-2.5 В в виде постоянного мигания, как будто перекрывает друг друга (между режимом с миганием раз в 3 секунды и разряженным режимом). Как в итоге это поправить?
Код: Выделить всё
#ifndef MAIN_H_
#define MAIN_H_
#define F_CPU 1200000UL
#include <util/delay.h>
#include <avr/io.h>
#include <avr/sleep.h>
#include <avr/interrupt.h>
#include <stdbool.h> // bool in C99
#define nop __asm__ __volatile__ ("nop");
typedef uint8_t u8;
typedef uint16_t u16;
int main(void);
static void setup(void);
static void wakeup(void);;
static u8 bat_getvoltage(void);
#endif /* MAIN_H_ */
#include <util/delay.h>
#include <avr/io.h>
#include <avr/sleep.h>
#include <avr/interrupt.h>
#include <stdbool.h> // bool in C99
int count = 0;
volatile uint8_t timer1 = 0;
volatile uint8_t timer2 = 0;
volatile uint8_t timerADC = 0;
volatile uint8_t countMode = 0; //????? ?????????? ??????
volatile uint8_t reqChangeMode = 0; //????, ???????????? ????? ????????? ???????? ?????
u8 adc_raw = 0;
volatile uint8_t timerADC2 = 0;
ISR(TIM0_COMPA_vect)
{
knopka_check();
bat_check();
}
ISR(TIM0_OVF_vect){}
u8 bat_getvoltage_knopka(void) {
_delay_us(50);
ADCSRA |= (1 << ADSC);
while (ADCSRA & (1 << ADSC));
return ADCH;
}
void bat_check(void)
{
u8 adc_raw = bat_getvoltage();
if ((adc_raw <= 207)&&(adc_raw > 183))
{
if (countMode == 1)
{
PORTB = 0b00000111;
} else if (countMode == 0)
{
PORTB = 0b00000101;
}
} else if ((adc_raw <= 183)&&(adc_raw > 130))
{
if (countMode == 1)
{
timer1++;
PORTB = 0b00001011;
if(timer1 == 100)
{
PORTB = 0b00001000;
timer1 = 0;
}
} else if (countMode == 0)
{
timer1++;
PORTB = 0b00001001;
if(timer1 == 100)
{
PORTB = 0b00001000;
timer1 = 0;
}
}
} else if (adc_raw <= 130)
{
if (countMode == 1)
{
timer2++;
PORTB = 0b00001111;
if (timer2 >= 3)
{
PORTB = 0b00001100;
}
if (timer2 >= 103)
{
PORTB = 0b00001111;
timer2 = 0;
}
} else if (countMode == 0)
{
timer2++;
PORTB = 0b00001101;
if (timer2 >= 3)
{
PORTB = 0b00001100;
}
if (timer2 >= 103)
{
PORTB = 0b00001101;
timer2 = 0;
}
}
} else if (adc_raw > 210)
{
if (countMode == 1)
{
PORTB = 0b00001111;
} else if (countMode == 0)
{
PORTB = 0b00001101;
}
} else if (adc_raw < 30)
{
DDRB = 0b00000011;
PORTB = 0b00000000;
}
}
void knopka_check(void) {
u8 adc_knopki = bat_getvoltage_knopka();
if (adc_knopki < 90)
{
if (count < 250)
count++;
} else {
if (count > 0)
count--;
if ((count >= 4)&&(count < 50))
{
countMode = (countMode + 1) & 0x1;
reqChangeMode = 1;
count = 0;
}
}
if (reqChangeMode) { //???? ????????? ???????? ?????
reqChangeMode = 0; //???????? ?????????
switch (countMode) { //?????????? ????? ??????
case 0:
{
PORTB = 0b00001101;
}
break;
case 1:
{
PORTB = 0b00001111;
}
break;
}
}
}
int main(void) {
setup();
sei ();
while(1) {
}
}
void setup(void){
ADMUX =
(1 << ADLAR) | (1 << REFS0) | (1 << MUX1) | (0 << MUX0);
ADCSRA |= (1 << ADEN)|(1 << ADPS2)|(1 << ADPS1)|(1 << ADATE); // Предделитель на 64 (частота АЦП 125kHz)
ADCSRB = (1 << ADTS1)|(1 << ADTS0);
// Выключаем аналоговый компаратор
ACSR=(1<<ACD) | (0<<ACBG) | (0<<ACO) | (1<<ACI) | (0<<ACIE) | (0<<ACIS1) | (0<<ACIS0);
TCCR0B = (0 << CS02) | (1 << CS01) | (1 << CS00 ); // тактовый генератор CLK/64
TCCR0A = (0 << WGM02) | (1 << WGM01) | (0 << WGM00); // Режим CTC
OCR0A = 69;
TCNT0 = 0;
TIMSK0|=(1<<OCIE0A)|(0<<TOIE0);
DDRB = 0b00001111;
PORTB = 0b00001101;
wakeup();
}
void wakeup(void) {
ADCSRA |= (1 << ADSC);
}
u8 bat_getvoltage(void) {
_delay_us(50);
ADCSRA |= (1 << ADSC);
while ((ADCSRA & (1<<ADIF))==0);
ADCSRA|=(1<<ADIF);
return ADCH;
}
написано много лишнего.
допустим такое:
надо писать примерно так:
допустим такое:
Код: Выделить всё
else if ((adc_raw <= 183) && (adc_raw > 130)) {
if (countMode == 1) {
timer1++;
PORTB = 0b00001011;
if (timer1 == 100) {
PORTB = 0b00001000;
timer1 = 0;
}
}
else if (countMode == 0) {
timer1++;
PORTB = 0b00001001;
if (timer1 == 100) {
PORTB = 0b00001000;
timer1 = 0;
}
}
}Код: Выделить всё
else if ((adc_raw <= 183) && (adc_raw > 130)) {
if (++timer1 == 100) {
timer1 = 0;
PORTB = 0b1000;
}
else
PORTB = (countMode) ? 0b1011 : 0b1001;
}ohmycode!
primuss3.com
primuss3.com
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
slav0n, допустим, но мне бы лучше не по сокращению кода, а именно по проблеме помощь
да просто никому нет дела до твоего чудокода
ohmycode!
primuss3.com
primuss3.com
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
slav0n, "очень приятно", спасибо. когда приходишь с проблемой, а тыкают в написание
так проблема же и заключается в написании
ohmycode!
primuss3.com
primuss3.com
- Сообщения: 66
- Зарегистрирован: Вт авг 07, 2018 09:44:46
slav0n, с каких пор помеха вылазит от более длинного написания одного и того же?
я так понял ты свой код переписывать не хочешь.
ну, как хочешь
ну, как хочешь
ohmycode!
primuss3.com
primuss3.com


