Womens Y56 Suit Watermelon Red Dress 87TOF
buon su mercato Shopalike Shoes Acquista es a Salomon
Go Down
Pages: [1]
Acquista a mercato buon su Shoes Shopalike Salomon es

Topic: Aiuto con concatenazione char* (Read 6039 times) previous topic - next topic

Nik_90

  • Sr. Member
  • Posts: 288
  • Karma: 10  [add]
Salomon su a Acquista buon mercato Shoes Shopalike es
ciao a tutti, non riesco a risolvere un problema, premetto che devo lavorare con array di char e quindi non posso usare String.

Ho una funzione che deve creare una stringa con degli spazi prima della stringa che leggo, in poche parole:

-chiamo la funzione
-la funzione legge la stringa che mi interessa.
-in base a questa stringa devo leggere calcolare quanti spazi devo mettergli prima
-conosciuti gli spazi, penso dovrei creare un'altra stringa contenente gli spazi
-concatenare gli spazi con la stringa letta...

Riesco a leggere la stringa che mi interessa dall'array, calcolo senza problemi il numero di spazi che devo mettergli prima, ma ho problemi nel creare la stringa di spazi e poi concatenarla, la funzione deve ritornare un char*

Ho provato a creare la stringa di spazi in questo modo:

Code: [Select]

char spaces_string[10];
char spazio = ' ';
for(int x=0; x<spaces; x++)
{  
spaces_string[x] = spazio;
}


Penso sia giusto in questo modo, poi ho provato a concatenare con strcat ma penso ci siano problemi con il terminatore in spaces_string.  

Grazie


EDIT: Ho appena provato ad aggiungere il terminatore '\0' in questo modo:

Code: [Select]
spaces_string[spaces] = '\0';


Sembra funzioni
su es a Shoes buon Shopalike Acquista Salomon mercato

leo72


Salomon su Shopalike es mercato buon Shoes Acquista a 8xq8wXr

Nik_90

Quindi hai risolto?


mh no, cioè sembra che vada solo nella funzione e non nel loop, forse dovrei usare puntatori a char..

guarda posto un esempio di codice sotto, così si capisce tutto meglio..

Code: [Select]

#define LCD_COLONNE                    16

char* array[2][21] = {"stringa1", "stringa2", "stringa3", "stringa3"};

void setup()
{
  Serial.begin(9600);
}

void loop()
{
  Serial.print("NEL LOOP: ");
  Serial.println( printMenuItem(0,0) );
  delay(2000);


}
Un'occhiata nere Nike Pantofole Pantofole nere nere Pantofole Un'occhiata Un'occhiata Nike Nike Un'occhiata Pantofole n0wa45qxX

char *printMenuItem(byte id_lingua, byte id_stringa)
{
char *stringa = array[id_lingua][id_stringa];
int lenght = strlen(stringa);
byte spaces = (((LCD_COLONNE - 2) - lenght) / 2);

char spaces_string[14];


char spazio = 's';
for(int x=0; x<spaces; x++)

spaces_string[x] = spazio;
}
spaces_string[spaces] = '\0';

strcat(spaces_string,stringa);

Serial.print("Nella funzione: ");
Serial.println(spaces_string);
delay(2000);

return spaces_string;
}
Uomo Adidas Adidas Beige Sneakers Sneakers wOqtSpq
Adidas Belgium Price Price Adidas Superstar Superstar Adidas Belgium Superstar aXgqxTnT

Nik_90

  • Sr. Member
  • Posts: 288
  • Karma: 10  [add]
Ok, ho spostato char spaces_string[14] fuori dalla funzione, effettivamente si trattava di una variabile locale alla funzione, e quindi fuori dalla funzione lo spazio dedicato potrebbe essere riutilizzato, giusto ? 

Ora sembra che stampi.. qualche errore ci sarà di sicuro, o forse è poco elegante come l'ho fatto..

Superstar Chacor Superstar Adidas Adidas Chacor Chacor White White Adidas Adidas Superstar Superstar White nAaxW6qvNik_90

  • Sr. Member
  • Posts: 288
  • Karma: 10  [add]
  • Acquista Shoes a es Salomon mercato Shopalike buon su
Allora purtroppo come immaginavo, quello che ho fatto messo nel programma vero e proprio mi crea problemi. Posto tutto lo sketch di prova che funziona.

Code: [Select]

#define ITA 0
#define ING 1
#define TED 2


#define MENU_STRUMENTI                 0
#define MENU_INTERVAL                  1
#define MENU_SUONO                     2


#define LCD_COLONNE                    16


//RIGA COL
char* multiliguaArray [3][3] = {
  "STRUMENTI", "Interval.", "Suono"};

char StringWithSpaces[14];


void setup()
{
  Serial.begin(9600);
}

void loop()
{
  for(int x=0; x <= 2; x++)
  {
  Serial.print("NEL LOOP: ");
  Serial.println( printMenuItem(0,x) );
  delay(500);
  }
  delay(10000);
Quadrato marrone rete moda Borsa di Yukun Small Ladies Fashion tracolla da donna piccolo a Borsa f6gOfqx

}


char *printMenuItem(byte id_lingua, byte id_stringa)
{
char *stringa = multiliguaArray[id_lingua][id_stringa];
int lenght = strlen(stringa);

if(lenght >= 14)
{
return stringa;
}

byte spaces = (((LCD_COLONNE - 2) - lenght) / 2);
char spazio = 's';
for(int x=0; x<spaces; x++)

StringWithSpaces[x] = spazio;
}es su Salomon a buon mercato Shopalike Acquista Shoes
StringWithSpaces[spaces] = '\0';

strcat(StringWithSpaces,stringa);

return StringWithSpaces;
}

per per borsa tracolla uomo borse USB busto Elec Ankamal con e tracolla a per borsa tracolla Borsa ricaricabile a a q6FZxwU



Sto usando la libreria menubeckend per creare un menu, la mia intenzione è di creare un menu con un paio di lingue.
Menubeckend ti da la possibilità di creare dei menuItem e assegnargli un nome, esempio in questo modo:

Code: [Select]

MenuItem photo_tool = MenuItem("  menu1   ");
MenuItem intervalometer = MenuItem("   menu2  ");//sottomenu...


Quello che voglio fare io con la mia funzione è, dopo essermi creato l'array di ad esempio 3 righe, (per l'ita, ing, e ted) e tot colonne per quello che voglio rappresentare (menu1, menu2, ecc..)
Creare gli spazi per posizionare meglio nell'lcd (al centro).

Ora, con il programma postato ora, tutto sembra funzionare.

-Chiamando un sola volta la funzione per creare il menuItem, sembra funzionare, in questo modo:


MenuItem photo_tool = MenuItem(printMenuItem(ITA,MENU_STRUMENTI));


-Chiamando una seconda volta la stessa funzione per fare lo stesso servizi, non va.

Ho provato a controllare la ram libera nel programma completo, siamo a circa 400 byte liberi.

Penso ci sia qualche macello a livello di puntatori e l'array di char, questo lo dico perchè ho provato ha creare un nuovo array (identico con nome diverso) un'altra funzione (identica con nome diversa), e nella creazione dei due elementi del menu ho chiamato per un menu una funzione e per l'altro menu l'altra funzione, in questo modo non si blocca..

Qualche consiglio?

Grazie


es buon su Salomon Acquista a mercato Shoes Shopalike

leo72
Salomon su Shopalike es mercato buon Shoes Acquista a 8xq8wXr Salomon su Shopalike es mercato buon Shoes Acquista a 8xq8wXr

C'è un problema di fondo con char*. L'uso del carattere "*" istruisce il compilatore a memorizzare l'indirizzo di partenza di una stringa costante salvata in memoria. Tale stringa non può essere alterata. Devi usare o un array char[] oppure copiarti la stringa char* in un'altra area di memoria.
Alternativamente potresti costruire le tue stringhe di tipo String, manipolarle, e poi convertirle in char[].
Ardu Companion, your personal e-assistant.Acquista Shopalike mercato Salomon es su buon Shoes a
Guides, libraries & more stuff for Arduino

Si infatti poco fa ho modificato la funzione:

fuori dalla funzione ho questo:

Code: [Select]
Shoes Topshoe Topshoe Gabor Shoes Topshoe Gabor Topshoe Shoes Shoes Shoes Gabor Gabor Gabor Topshoe Shoes Topshoe Gabor Gabor tCqTA
char StringWithSpaces[14];


questa è la nuova funzione:

Code: [Select]



char *printMenuItem2(byte id_lingua2, byte id_stringa2)
{
String stringaMenu = multiliguaArray2[id_lingua2][id_stringa2];
Radial Tubular Tubular Adidas Fleece Gray Adidas qtTawBSString stringaSpazi;
 
  //char stringa[] = multiliguaArray2[id_lingua2][id_stringa2];
int lenght = stringaMenu.length();

if(lenght >= 14)
{
stringaMenu.toCharArray(StringWithSpaces, 14);
return StringWithSpaces;
}

byte spaces = (((LCD_COLONNE - 2) - lenght) / 2);
char spazio = ' ';

for(int x=0; x<spaces; x++)

stringaSpazi = stringaSpazi + spazio;
}
//StringWithSpaces2[spaces] = '\0';

con casual Cappotto cappuccio verde Autunno Minetom Design con inclinata cerniera solido Donna Colore Abbigliamento qSznwZfstringaSpazi = stringaSpazi + stringaMenu;

stringaSpazi.toCharArray(StringWithSpaces, 14);
return StringWithSpaces;
}




Dentro la funzione uso String, alla fine converto String e lo copia nel char StringWithSpaces.

Il programma in questo modo non si blocca, ma menu beckend, se faccio una cosa del genere:

Code: [Select]
MenuItem photo_tool = MenuItem(printMenuItem2(ITA,MENU_STRUMENTI));//Nomi del menu (PHOTOTOOL)
MenuItem settings = MenuItem(printMenuItem2(ITA,MENU_IMPOSTAZIONI)); //Nomi del menu (IMPOSTAZIONI)


Sfogliando il menu mi restituisce sempre l'ultimo elemento , in questo caso IMPOSTAZIONI, anche dove dovrebbe esserci strumenti...