реклама на сайте
подробности

 
 
> как правильно обработать ф-ю с дефайном?
Метценгерштейн
сообщение Apr 29 2015, 14:50
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 357
Регистрация: 12-04-05
Из: Петербург
Пользователь №: 4 079



есть некая ф-я,
Код
void sendDataToLCD (uint8_t _pos, uint8_t _data)
{
    if (_pos == 1)
    {
            switch (_data)
            {
                case 1:
                    ht1621_wr_bit( LCD_SEGMENT_B_POS1_SEG, LCD_SEGMENT_B_POS1_COM, 1);
                    ht1621_wr_bit( LCD_SEGMENT_C_POS1_SEG, LCD_SEGMENT_C_POS1_COM, 1);
                    break;

потом case 2, 3 и так далее будет.
как делать, чтобы вместо POS1 или просто вместо 1 подставлять _pos ?
сам LCD_SEGMENT_B_POS1_SEG - это дефайн
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 9)
CrimsonPig
сообщение Apr 29 2015, 15:01
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 329
Регистрация: 23-04-14
Пользователь №: 81 502



Цитата(Метценгерштейн @ Apr 29 2015, 15:50) *
есть некая ф-я,
потом case 2, 3 и так далее будет.
как делать, чтобы вместо POS1 или просто вместо 1 подставлять _pos ?
сам LCD_SEGMENT_B_POS1_SEG - это дефайн


написать кусочек кода (функцию, например), которая принимает аргументом uint8 _pos и в зависимости от него возвращает значение, которое надо передать первыми параметром в ht1621_wr_bit() это в данном конкретном случае.

"потом case 2, 3 и так далее будет."
Таки до скольки ? Сдается мне, что все это можно написать гораздо лучше. Если в коде вдруг начали появляться case 1: case 2: итп, которые делают почти одинаковые действия, то это обычно означаетт что что-то тут не то.

Go to the top of the page
 
+Quote Post
Метценгерштейн
сообщение Apr 29 2015, 18:14
Сообщение #3


Профессионал
*****

Группа: Свой
Сообщений: 1 357
Регистрация: 12-04-05
Из: Петербург
Пользователь №: 4 079



вывод на семисегментный индикатор. case от 0 до 9. А вот позиции от 1 до 4-х. И в дефайне меняется только POS1 на POS2...
Go to the top of the page
 
+Quote Post
редактор
сообщение Apr 30 2015, 05:35
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 356
Регистрация: 9-06-07
Пользователь №: 28 315



через локальную переменную.
Код
void sendDataToLCD (uint8_t _pos, uint8_t _data)
{  uint8_t ferst_param;
    if (_pos == 1)
      { ferst_param = LCD_SEGMENT_B_POS1_SEG;
        }
    else
     { ferst_param = LCD_SEGMENT_B_POS2_SEG;
      }
   //----
   switch (_data)
            {
                case 1:
                    ht1621_wr_bit( ferst_param, LCD_SEGMENT_B_POS1_COM, 1);
                    ht1621_wr_bit( ferst_param, LCD_SEGMENT_C_POS1_COM, 1);
                    break;

или через массив
Код
uint8_t FerstParams[MAX_PARAM_NUM]={LCD_SEGMENT_B_POS1_SEG,
                                                          LCD_SEGMENT_B_POS2_SEG,
                                                            ......
};
void sendDataToLCD (uint8_t _pos, uint8_t _data)
{  
    if (_pos >= MAX_PARAM_NUM )
      { return; // выход за границу масива
        }
    ferst_param = FerstParams[pos];
    //----
    switch (_data)
            {
                case 1:
                    ht1621_wr_bit( ferst_param, LCD_SEGMENT_B_POS1_COM, 1);
                    ht1621_wr_bit( ferst_param, LCD_SEGMENT_C_POS1_COM, 1);
                    break;

Можно пойти еще дальше и сделать двумерный массив, но как я понимаю количество вызовов ht1621_wr_bit для каждой цифры разное.


--------------------
Хорошую систему делают из стандартных блоков нестандартно мыслящие инженеры.
Go to the top of the page
 
+Quote Post
Метценгерштейн
сообщение Apr 30 2015, 06:06
Сообщение #5


Профессионал
*****

Группа: Свой
Сообщений: 1 357
Регистрация: 12-04-05
Из: Петербург
Пользователь №: 4 079



имею ввиду как-то через макрос что -ли.
Код
void sendDataToLCD (uint8_t _pos, uint8_t _data)
{
            switch (_data)
            {
                case 1:
                    ht1621_wr_bit( LCD_SEGMENT_B_POS(_pos )_SEG, LCD_SEGMENT_B_POS1_COM, 1);


как-то так.
Go to the top of the page
 
+Quote Post
psL
сообщение Apr 30 2015, 06:19
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 526
Регистрация: 5-08-05
Пользователь №: 7 390



Цитата(Метценгерштейн @ Apr 30 2015, 09:06) *
имею ввиду как-то через макрос что -ли.
Код
void sendDataToLCD (uint8_t _pos, uint8_t _data)
{
            switch (_data)
            {
                case 1:
                    ht1621_wr_bit( LCD_SEGMENT_B_POS(_pos )_SEG, LCD_SEGMENT_B_POS1_COM, 1);


как-то так.


Код
#define LCD_SEGMENT_B_POS_SEG(_pos )   {  ... (1<<_pos)... }

либо
Код
#define LCD_SEGMENT_B_POS_SEG(_pos )  { ... ## _pos ... }
Go to the top of the page
 
+Quote Post
редактор
сообщение Apr 30 2015, 09:17
Сообщение #7


Местный
***

Группа: Участник
Сообщений: 356
Регистрация: 9-06-07
Пользователь №: 28 315



Цитата
#define LCD_SEGMENT_B_POS_SEG(_pos ) { ... (1<<_pos)... }

В любом случае разбор параметра

Цитата
#define LCD_SEGMENT_B_POS_SEG(_pos ) { ... ## _pos ... }

не уверен что сработает, _pos - аргумент функции, который меняется при выполнении программы, а все дефайны определяются на этапе компиляции, поэтому подстановка имени будет некорректной (мое мнение, может и ошибочное).
Не люблю много макросов - запутаться можно.


--------------------
Хорошую систему делают из стандартных блоков нестандартно мыслящие инженеры.
Go to the top of the page
 
+Quote Post
XVR
сообщение Apr 30 2015, 10:02
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 3 123
Регистрация: 7-04-07
Из: Химки
Пользователь №: 26 847



Цитата(Метценгерштейн @ Apr 30 2015, 09:06) *
имею ввиду как-то через макрос что -ли.
...
как-то так.
как то так - никак rolleyes.gif
Макросы раскрываются С препроцессором, который работает до С компилятора и абсолютно независимо от него. Т.е. он (препроцессор) никак не может подставить вместо _pos его значение из параметра функции, просто потому что он не знает, что такое _pos - для него это просто кусочек текста, не более.
Go to the top of the page
 
+Quote Post
adnega
сообщение Apr 30 2015, 10:05
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 2 724
Регистрация: 14-05-07
Из: Ярославль, Россия
Пользователь №: 27 702



Цитата(Метценгерштейн @ Apr 30 2015, 09:06) *
имею ввиду как-то через макрос что -ли.

Вы путаете момент компиляции и момент исполнения кода.

Та как вы хотите будет выглядеть примерно так:
Код
#define SEG_POS(x) do{\
    if(_pos == (x))\
    {\
        switch(_data)\
        {\
            case 1:\
                ht1621_wr_bit( LCD_SEGMENT_B_POS##x##_SEG, LCD_SEGMENT_B_POS##x##_COM, 1);\
                ht1621_wr_bit( LCD_SEGMENT_C_POS##x##_SEG, LCD_SEGMENT_C_POS##x##_COM, 1);\
                break;\
        }\
    }}while(0)


Вызывать так SEG_POS(1).
Go to the top of the page
 
+Quote Post
esaulenka
сообщение Apr 30 2015, 10:23
Сообщение #10


Профессионал
*****

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



У меня предложение - выкинуть ВСЁ и сделать правильно.

Полез в гугл посмотреть, что такое этот HT1621, и наткнулся на весьма внятное описание у... ардуинщиков. Рекомендую .

ht1621.writeMem придётся самому делать, но, кажется мне, он уже готов.


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 29th July 2025 - 08:18
Рейтинг@Mail.ru


Страница сгенерированна за 0.01483 секунд с 7
ELECTRONIX ©2004-2016