Перейти к содержанию

Вопросы от начинающих по МК


Рекомендуемые сообщения

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

  • Ответов
  • Создана
  • Последний ответ

Топ авторов темы

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

полный пипец ...

патологическая неспособность действовать самостоятельно.

Мудрость приходит вместе с импотенцией...

Когда на русском форуме переходят на Вы, в реальной жизни начинают бить морду.

Ссылка на комментарий
Поделиться на другие сайты

1. :
char days[][12] = {
    "Понедельник", "Вторник", "Среда", "Четверг",
    "Пятница", "Суббота", "Воскресенье"
};

2. :
Lcd_prints(7,0, FONT_1X,(unsigned char *)PSTR(days[2][12])); 
-----------------------------
Первое съело, второе не хочет.

Ссылка на комментарий
Поделиться на другие сайты

Согласен.
Вот только Вы бы сказали, как применить эту "красоту писаную"...

... применительно к дисплею 5110.

Изменено пользователем Юрий_Нд
Ссылка на комментарий
Поделиться на другие сайты

5 minutes ago, Юрий_Нд said:

там всё для stm32

Для STM32 там только аппаратно-зависимая часть. А остальное - общее. Слова выводятся посимвольно. Вот такая простая функция рисует строки:

	U8 *pcd8544_print(U8 *koi8){
	while(*koi8){
	U8 chr = *koi8;
	if(pcd8544_putch(chr) == chr) return koi8;
	++koi8;
	}
	return NULL;
	}

(правда, писал я это давненько, сейчас бы сделал более рационально все).

Если эта функция вернет не-NULL, значит, целиком строка на экран не влезла - нужно чуть подождать, чтобы пользователь первую строчку прочел, и сделать pcd8544_roll_screen().

А если есть проблемы собственно с С, советую Кернигана и Ритчи почитать, а после них можно еще о современном C11 (правда, порекомендовать ничего не могу на этот счет: вся литература, что я встречал по современному С, - лютое дерьмо; вот по старому С99 можно Богатырева почитать - рекомендую).

Ссылка на комментарий
Поделиться на другие сайты

От корки до корки, раз такая беда с языком! И упражнениями закрепить.

Указатели - это же так просто! И указатель - основной элемент языка. Нужно понимать, что такое указатель, массив, ссылка на переменную… Чем массив указателей отличается от двойного массива типа "char".

Изменено пользователем Eddy_Em
Ссылка на комментарий
Поделиться на другие сайты

Вы уж меня извините, но вместо Вашей простенькой функции с Керниган и Ритчи впридачу, я всё-таки предпочту переключатель switch.
Может быть этот оператор не шибко красиво смотреться будет, зато это понятно, прозрачно "и сейчас". И может быть, самое главное, кланяться никому не придётся.
В любом случае, большое спасибо за диалог, заходите почаще, 
С уважением ___________ Юрий.
п.с. "Полторы тыщи" страниц? Это что, через полгода мне программу свою написать из-за одной строчки?
Извиняйте.

Изменено пользователем Юрий_Нд
Ссылка на комментарий
Поделиться на другие сайты

А чего делать-то нужно? Просто писать дни недели? Ну так это легко (пусть N - номер дня недели, 0 - воскресенье; и тип строковых переменных можно спокойно на char поменять с  uint8_t):

const char *days = {"воскресенье", "понедельник", "вторник", "среда", "четверг", "пятница", "суббота"};
	... // здесь что-то с N делают и проверяют, чтобы не вышло за пределы 0..6
	char *nxt = pcd8544_print(days[N]);
	if(nxt){
	  pcd8544_roll_screen();
	  pcd8544_print(nxt);
	}

И с Lcd_prints:

	Lcd_prints(7,0, FONT_1X, (unsigned char *)days[N]); 
	

// там тоже стоит uint8_t на обычный знаковый char поменять, чтобы не приводить типы вечно туда-сюда.

P.S. Да, полторы тысячи страниц. Или даже больше.

Либо человек учится, либо остается некомпетентным бездарем и городит непонятную фигню!

Вам же не западло было пару тысяч страниц литературы прочесть, прежде чем начать эффективно компьютер использовать? Вот и программирование - штука нелегкая. Я в свое время минимум тысяч 25 страниц разной литературы прочел, чтобы просто понять, что да как. А потом регулярно бестселлеры перечитываю: по линуксовым IPC; кнутовский "все про ТеХ"; Львовского о латехе; тех же Кернигана и Ритчи нет-нет, да почитаю; Хоровица и Хилла ну и т.д., и т.п.

И даташиты/мануалы постоянно читать приходится. И статьи о всяких разных алгоритмах и не только. И это при том, что я - не программист и не электронщик!

Ссылка на комментарий
Поделиться на другие сайты

В данном конкретном случае, всего лишь три слова:
Первый, второй, третий, в зависимости от переменной инт ноэл, принимающей значение 1, 2, 3.

------------------------------------------------------------------------------------------------------------------------------

Ну хорошо, допустим мне всё понятно в Вашем последнем сообщении.
Что ещё нужно подключать, какие библиотеки? Типа заголовочные и исходные файлы?

Изменено пользователем Юрий_Нд
Ссылка на комментарий
Поделиться на другие сайты

@Eddy_Em  Наверно, правильнее объявить не одинокий указатель, а массив указателей.

char *days[] = {"воскресенье", "понедельник", "вторник", "среда", "четверг", "пятница", "суббота"};

 

Ссылка на комментарий
Поделиться на другие сайты

const char *number = {"первый", "второй", "третий"};

... // здесь что-то с N делают и проверяют, чтобы не вышло за пределы 0..2

char *nxt = pcd8544_print(days[2]);

if(nxt){   pcd8544_roll_screen();   pcd8544_print(nxt); }

--------------------------------------------------------

третий

----

верно?

 

19 минут назад, Yurkin2015 сказал:

массив указателей.

... а дальше?

Изменено пользователем Юрий_Нд
Ссылка на комментарий
Поделиться на другие сайты

51 минуту назад, Eddy_Em сказал:

Указатели...

Ну указатели "это ещё куда ни шло", по крайней мере не "Полторы тыщи" страниц.  За день-два можно и осилить.  С остальными иероглифами  мне вроде бы всё понятно. 
Да в принципе и с указателями, "не такой уж и тёмный этот лес". 
Я конечно не знаю что такое указатели,  но по-моему работать с ними уже умею?
-----------------------
Или Вы уже отдыхаете?
Ну тогда спокойной ночи.
Ещё раз большое спасибо Вам, за сегодняшний диалог,
С Уважением _____________ Юрий.

Ссылка на комментарий
Поделиться на другие сайты

Извиняюсь, а вот мне всё-таки не спится, потому что сейчас посмотрел на это всё и указатели...
 И понял, что нифига не понимаю.
Ну вот скажу я своему дисплею вывести мне слово "третий".
А он мне в ответ:"... ты чо, дурак что ли? А где номер строчки, позиции, размер шрифта? Где я это всё "лепить" буду? "Промежду" строчками что-ли"
И что мне ответить ему?
Типа ни фига не знаю, надо у Eddy_Em спросить?
Ну вот считайте, что уже спрашиваю...

Нет мужики, я пока за переключатель Switch.

Изменено пользователем Юрий_Нд
Ссылка на комментарий
Поделиться на другие сайты

50 minutes ago, Юрий_Нд said:

... а дальше?

а дальше просто передаёте в печать нужный указатель на строку, которую надо напечатать.

pcd8544_print(days[N]);

 

@Юрий_Нд Обычно у дисплеев есть команды, которые помещают курсор в нужное место. Сначала посылается команда установки курсора, а затем посылается текст для печати.

Ссылка на комментарий
Поделиться на другие сайты

А по-моему, к Вам нужно адресовать всё те же вопросы, которые я только что задал Eddy_Em.
Вернитесь чуть назад, прочитайте пожалуйста.
А то я опять "нарвусь" на замечание модератора.

 

Ссылка на комментарий
Поделиться на другие сайты

1 hour ago, Юрий_Нд said:

к Вам нужно адресовать

On 11/5/2021 at 10:18 AM, Юрий_Нд said:

После  (1<<0) получается 0bххххххх1,

Число 1 в человеческом десятичном понимании, а для процессора в двоичном виде равно 0b00000001. То есть не крестики, а обычные нули.

Поэтому после сдвига такого числа влево на ноль позиций в результате получим точно такое же значение 0b00000001

 

On 11/6/2021 at 1:08 PM, Юрий_Нд said:

можно количество значащих цифр

Тип float даёт 7 значащих цифр.

Изменено пользователем Yurkin2015
Ссылка на комментарий
Поделиться на другие сайты

 

11 часов назад, Eddy_Em сказал:

А если есть проблемы собственно с С, советую Кернигана и Ритчи почитать

На гражданина это заклинание не действует. Проверено.

Изменено пользователем LiVit
Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы публикуете как гость. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Сообщения

    • Автору. Никаких тут 250...200 ватт у этой китайской бздюшки нет в помине. Тем паче на таком подобии радиатора Катушки даже на выходе нет-плохо  
    • Повторюсь - НЕТ, так как у вас там крутилки, что приведет к искажениям при работе в мостовой схеме. Если бы вы "могли" то вам нужно было разорвать выход с темброблока и вход усилителей и впаять (можно навесом) вот такую схему:
    • Все верно, вы почти все что нужно сделали.  Только не нужно было добавлять это b=UDR; Сразу после старта сбросить флаг flags = 0; А в основном цикле ждать установки флага FLAG_END_RX. И если он установлен, проверять на совпадение строки в буфере (rx_buf) с вашей строкой (AT+QM \ r \ n .....   .....  AT+MP \ r \ n) При совпадении вызывать выполнение нужного алгоритма.
    • У меня до саба ещё дело не дошло, только сейчас думаю купить амп на полкиловатта, но так можно, при условии, что на входе будет моно, и будет срез частот
    • Про флаг Т: если он не используется в основной программе, а у меня он постоянно в деле. для меня меня отложенная обработка прерывания обычное дело, нужно лишь правильно расставить приоритеты частей программы. И обычное дело: выставляешь частоту задающего генератора побольше, делишь его до получения частоты 1000 Гц каким либо таймером, загоняешь в прерывание с флагом. затем закольцовываешь основную программу с проверкой флага прерывания от таймера 1000Гц. загоняешь программу в Sleep. Получаешь кольцо обработки с образцовым интервалом в 1 мс. После любого прерывания проверяешь флаг от таймера, если он, то сбрасываешь флаг и начинаешь перебирать подпрограммы обработки индикаторов, клавиатуры, и тд. и тп, подпрограммы обработки флагов и др. После окончания обработки всех подпрограмм возвращаешься к Sleep. И так по кольцу. Если происходит прерывание не от таймера, программа выходит из Sleep, проверяется флаг от таймера, если не он (а это не он) обратно к Sleep. В большенстве программ использую этот алгоритм.   GPIOR1 и GPIOR2 в 88 условно можно использовать как флаги, но их адреса больше 0х1Е, на них не распространяются команды cbi, sbi, sbic, sbis, и их сначала нужно загрузить в общий регистр, промодифицировать, и заново сохранить. Эта последовательность длинная, и модифицирует SREG, что сводит на нет работу по сравнению с  классическим GPIOR.
    • @korsaj Сегодня попробовал сделать как ты посоветовал. Получился следующий код. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> #include <stdlib.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) #define FLAG_END_RX (1<<3) #define FLAG_ERR_RX (1<<4) #define BUF_SIZE 20 char rx_buf[BUF_SIZE]; char buf_index = 0; volatile start=1, flags; char b; ISR(USART_RXC_vect) { b=UDR; if(!(flags & FLAG_END_RX)) { rx_buf[buf_index]=UDR; if(rx_buf[buf_index] == 0x0D) { flags |= FLAG_END_RX; return; } buf_index++; if(buf_index >= BUF_SIZE) { buf_index = 0; flags |= FLAG_ERR_RX; } } } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); flags = 0; } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Ну как сказать всё работает, но вот меня очень интересует приём команд на саму ATMEGA16. Он так и работает только с цифрами. Более ничего корректно принять не получается даже используя таблицу ascii. А мне нужно будет принимать команды и посложней чем просто буквенно - цифровые. Потому как возвращаясь к командам самого плеера там в этих командах хранятся различные данные. Вот примерно так это всё выглядит. AT+QM \ r \ n Запрос режима работы [0: Bluetooth], [1: MP3] AT+M1 \ r \ n Номер текущего файла AT+M2 \ r \ n Общее количество звуковых файлов AT+MD \ r \ n Источник музыки USB или SD Card AT+MT \ r \ n Общее время воспроизведения текущего файла AT+MK \ r \ n Время воспроизведения текущего файла AT+MP \ r \ n Текущее состояние плеера [0]Стоп, [1]Воспроизведение, [2]Пауза К примеру при отправке команды AT+M1 \ r \ n в ответ мы получим M1 + 000002 \ r \ n при этом здесь может быть любое число в hex формате. Мне же нужно каким то образом принять эти данные и обработать их соответствующим образом. Но при этом и нужно учитывать так же что плеер может сам отправить эти данные по началу воспроизведения трека. Вот в этом сейчас и стоит основная задача. Чего я и пытаюсь получить в итоге.
  • Похожий контент

×
×
  • Создать...