|
Указатель на строку в структуре, или даже указатель на указатель |
|
|
|
Aug 3 2011, 11:18
|

Местный
  
Группа: Свой
Сообщений: 381
Регистрация: 5-07-05
Из: Уфа
Пользователь №: 6 544

|
Нужна помощь опытных специалистов. Код такой: Код typedef struct { int x_numicons; int y_numicons; int iconnumber[10]; } imenu_icons_t;
typedef struct { imenu_icons_t *menu_idle; imenu_icons_t *menu_active; imenu_icons_t *menu_icon; char *menu_text[10]; } imenu_t;
imenu_icons_t main_icon = {1, 1, {2, 3, 4, 5, 6, 7, 8, 9, 10, 11}};
imenu_icons_t main_idle = {10, 1, {12, 13, 14, 15, 16, 17, 18, 19, 20, 21}};
imenu_icons_t main_active = {10, 1, {22, 23, 24, 25, 26, 27, 28, 29, 30, 31}};
const char *main_text[10] = {"STR1", "STR2", "STR3", "STR4", "STR5", "STR6", "STR7", "STR8", "STR9", "STR10"};
imenu_t mainmenu = {&main_idle, &main_active, &main_icon, &main_text};
int icon_menu(imenu_t *pmenu) { unsigned char current = 0, i; char *ptr;
// В функции показано не все, поэтому пусть не смущает ее бессмысленность
for(i = 0; i < entries; i++) { ptr = (char *)pmenu->menu_text[i]; }
return current; }
unsigned char ic;
void main(void) { ic = icon_menu(&mainmenu); } беспокоит строка: ptr = (char *)pmenu->menu_text[i]; так как сейчас она указывает не туда куда хотелось бы. Вопрос в том как это правильно сделать, т.е. чтобы указатель указывал на строку?
Сообщение отредактировал 011119xx - Aug 3 2011, 11:20
|
|
|
|
|
Aug 3 2011, 11:39
|

Гуру
     
Группа: Свой
Сообщений: 2 399
Регистрация: 10-05-06
Из: г. Новочеркасск
Пользователь №: 16 954

|
Цитата(011119xx @ Aug 3 2011, 15:18)  как это правильно сделать, т.е. чтобы указатель указывал на строку? Скорее всего, так: Код imenu_t mainmenu = {&main_idle, &main_active, &main_icon, {main_text[0], main_text[2], main_text[3], main_text[4], main_text[5], main_text[6], main_text[7], main_text[8], main_text[9] } };
|
|
|
|
|
Aug 3 2011, 11:40
|

Местный
  
Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631

|
Лучше работать с указателем на массив указателей на строки. CODE typedef struct {
u8 QtyString;
u8 **pStr;
} MENU_PageText;
const u8 *MENU_TEXT_RU[] =
{
"выаопвылаопвыо",
"ывалдоплвыоапло",
"ывавыавыоапио"
};
..........
..........
const MENU_PageText PagesText[] =
{
{0x3,MENU_TEXT_EN},
{0x3, MENU_TEXT_DE},
{0x3,MENU_TEXT_IT},
{0x3, MENU_TEXT_RU}
};
Сообщение отредактировал ISK2010 - Aug 3 2011, 11:46
|
|
|
|
|
Aug 3 2011, 13:02
|
Гуру
     
Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823

|
Цитата(ISK2010 @ Aug 3 2011, 14:40)  Лучше работать с указателем на массив указателей на строки. Не факт, но инициализировать меню удобрее с помощью макросов, типа: Код STATE ( Abort , "Aborted !" , "Entnahme abgebrochen!" ,"Остановлено!" , CLR+STN+OLD+SSS+SLB ) STATE ( Finish , "Finished:" , "Beendet:" ,"Закончено:" , CLR+STN+OLD+SSS+SLB )
--------------------
Уходя, оставьте свет...
|
|
|
|
|
Aug 4 2011, 10:27
|

Местный
  
Группа: Свой
Сообщений: 381
Регистрация: 5-07-05
Из: Уфа
Пользователь №: 6 544

|
Проблема решается так: Код typedef struct { int x_numicons; int y_numicons; int iconnumber[10]; } imenu_icons_t;
typedef struct { imenu_icons_t *menu_idle; imenu_icons_t *menu_active; imenu_icons_t *menu_icon; char *menu_text[10]; } imenu_t;
imenu_icons_t main_icon = {1, 1, {2, 3, 4, 5, 6, 7, 8, 9, 10, 11}};
imenu_icons_t main_idle = {10, 1, {12, 13, 14, 15, 16, 17, 18, 19, 20, 21}};
imenu_icons_t main_active = {10, 1, {22, 23, 24, 25, 26, 27, 28, 29, 30, 31}};
const char *main_text[10] = {"STR1", "STR2", "STR3", "STR4", "STR5", "STR6", "STR7", "STR8", "STR9", "STR10"};
imenu_t mainmenu = {&main_idle, &main_active, &main_icon, &main_text};
void print(char *text) { char c;
while(c = *(text++)) { // Печать символа } }
int icon_menu(imenu_t *pmenu) { unsigned char current = 0, i; char **ptr = (char *)pmenu->menu_text[0];
for(i = 0; i < entries; i++) { print(*(ptr + i)); }
return current; }
unsigned char ic;
void main(void) { ic = icon_menu(&mainmenu); }
|
|
|
|
|
Aug 4 2011, 11:05
|

Гуру
     
Группа: Свой
Сообщений: 2 399
Регистрация: 10-05-06
Из: г. Новочеркасск
Пользователь №: 16 954

|
Цитата(011119xx @ Aug 4 2011, 14:27)  Проблема решается так "Кривое" решение. Корректнее это сделать так: Код ... typedef struct { imenu_icons_t *menu_idle; imenu_icons_t *menu_active; imenu_icons_t *menu_icon; char **menu_text; } imenu_t; ..... const char *main_text[10] = {"STR1", "STR2", "STR3", "STR4", "STR5", "STR6", "STR7", "STR8", "STR9", "STR10"};
imenu_t mainmenu = {&main_idle, &main_active, &main_icon, &main_text};
..... int icon_menu(imenu_t *pmenu) { unsigned char current = 0, i; char **ptr = pmenu->menu_text;
.... } ....
|
|
|
|
|
Aug 5 2011, 02:45
|

Местный
  
Группа: Свой
Сообщений: 381
Регистрация: 5-07-05
Из: Уфа
Пользователь №: 6 544

|
Keil ваш вариант не устраивает. А вот такой устраивает: Код ... typedef struct { imenu_icons_t *menu_idle; imenu_icons_t *menu_active; imenu_icons_t *menu_icon; const char **menu_text; } imenu_t; ..... const char *main_text[10] = {"STR1", "STR2", "STR3", "STR4", "STR5", "STR6", "STR7", "STR8", "STR9", "STR10"};
imenu_t mainmenu = {&main_idle, &main_active, &main_icon, main_text};
..... int icon_menu(imenu_t *pmenu) { unsigned char current = 0, i; const char **ptr = pmenu->menu_text;
for(i = 0; i < entries; i++) { print((char *)(ptr + i)); } .... } ....
Сообщение отредактировал 011119xx - Aug 5 2011, 02:46
|
|
|
|
|
Aug 5 2011, 16:23
|
self made
   
Группа: Свой
Сообщений: 855
Регистрация: 7-03-09
Из: Toronto, Canada
Пользователь №: 45 795

|
Цитата(011119xx @ Aug 4 2011, 06:27)  Проблема решается так: Подтверждаю, кривое, если не сказать кривейшее. Массив на 10 элементов, используется и инициализируется только один. Используется причем неправильно. Код char **ptr = (char *)pmenu->menu_text[0]; В этой строке вам ничего глаз не режет?
|
|
|
|
|
Aug 8 2011, 02:44
|

Местный
  
Группа: Свой
Сообщений: 381
Регистрация: 5-07-05
Из: Уфа
Пользователь №: 6 544

|
Окончательный вариант принятый к использованию: Код ... typedef struct { imenu_icons_t *menu_idle; imenu_icons_t *menu_active; imenu_icons_t *menu_icon; const char **menu_text; } imenu_t; ..... const char *main_text[10] = {"STR1", "STR2", "STR3", "STR4", "STR5", "STR6", "STR7", "STR8", "STR9", "STR10"};
imenu_t mainmenu = {&main_idle, &main_active, &main_icon, main_text};
..... int icon_menu(imenu_t *pmenu) { unsigned char i, entries;
.... for(i = 0; i < entries; i++) { print((char *)pmenu->menu_text[current]); } .... } ....
|
|
|
|
|
Aug 8 2011, 07:50
|
Профессионал
    
Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007

|
Цитата(011119xx @ Aug 8 2011, 06:44)  Окончательный вариант принятый к использованию: Код .... for(i = 0; i < entries; i++) { print((char *)pmenu->menu_text[current]); } .... } Просто глаз радуется, глядя на цикл, в котором индекс никак не используется в теле.
|
|
|
|
|
Aug 8 2011, 08:33
|

Местный
  
Группа: Свой
Сообщений: 381
Регистрация: 5-07-05
Из: Уфа
Пользователь №: 6 544

|
Цитата(sergeeff @ Aug 8 2011, 13:50)  Просто глаз радуется, глядя на цикл, в котором индекс никак не используется в теле. Так нормально? Код .... for(i = 0; i < entries; i++) { print((char *)pmenu->menu_text[i]); } .... Цитата(XVR @ Aug 8 2011, 13:46)  Можно просто написать print(pmenu->menu_text[current]); Keil на такое ругается так как print объявлена: void print(char *str);
|
|
|
|
|
Aug 8 2011, 08:47
|
Профессионал
    
Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007

|
Цитата(011119xx @ Aug 8 2011, 12:33)  Так нормально? Код .... for(i = 0; i < entries; i++) { print((char *)pmenu->menu_text[i]); } .... Keil на такое ругается так как print объявлена: void print(char *str);Вам лучше знать, нормально это или нет. Вы же автор кода. Объявите функцию print: Код void print(const char *str); Тогда она будет без проблем вызываться с const и не const фактическими переменными.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|