Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-04-2011, 17:36   #1
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
[C++] SQLite - inserire/estrarre jpg

Sono 3 giorni che studio come fare in C++, ho trovato MOLTI articoli ma non ne vengo a capo. Ho trovato esempi come QUESTO, QUESTO e QUESTO, mi sono letto molte cose su http://www.sqlite.org e mille commenti di altre persone.
L'inserimento sono riuscito, ma non riesco a fare ad estrarre il jpg e poi poterlo usare come variabile in una classe C++. Provengo da Java, e il C/C++ mi da ancora molte grane.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-04-2011, 19:19   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Dovresti postare un pò di codice, nei link che hai indicato c'è la soluzione al tuo problema.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 17-04-2011, 19:47   #3
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Ho notato che l'insertion da me scritto non funzionava.
Si lo so che negli esempi c'è la soluzione, ma io dovrei modificarli in base alle mie classi e non ci riesco. In pratica nel DB ho un TABLE con 4 colonne. Ogni colonna è un attributo della mia classe Item:
Codice:
#include "Item.h"

	using namespace Tamagotchi;
	using namespace std;

	Item::Item(string aName, int aPrice, int anHappiness, FILE aPicture){
		name=aName;
		price=aPrice;
		happiness=anHappiness;
		picture = aPicture;
	}

	int Item::getPrice(){
		return price;
	}

	int Item::getHappiness(){
		return happiness;
	}

	string Item::getName(){
		return name;
	}

	FILE Item:: getPicture(){
		return picture;
	}
In pratica io dovrei andare a interrogare il DB in modo che mi ritorni un Oggetto di tipo Item. Il mio problema è il "ricreare" il file, con il resto non avrei problemi.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 10:17   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Si ma serve il codice che hai scritto per interrogare sqlite
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 13:30   #5
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Si ma serve il codice che hai scritto per interrogare sqlite
...è proprio quello che mi manca e serve.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 15:16   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
...è proprio quello che mi manca e serve.
Potresti cominciare copiando quello che hai trovato no?
Ad esempio questo è un esempio funzionanate: http://www.yolinux.com/TUTORIALS/SQLite.html#BLOB
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 15:24   #7
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Potresti cominciare copiando quello che hai trovato no?
Ad esempio questo è un esempio funzionanate: http://www.yolinux.com/TUTORIALS/SQLite.html#BLOB
Più tardi ci proverò di nuovo....ti faccio sapere.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 16:50   #8
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Allora, l'insertion che avevo fatto (ora cancellato perchè non mi serve più) era sbagliato perchè, se non erro, il quarto parametro di sqlite3_bind_blob() deve essere la dimensione del file in bytes. Forse se avessi cambiato quello, punzionava.
Comunque dato che l'insertion non serviva per la funzionalità del mio programma, ho optato per creare il DB a mano usando sqliteman di Linux. Ora però mi serve l'algoritmo di interrogazione. Partiamo dall'inizio. Se i valori restituiti fossero semplici valori (int o string) potrei usare semplicemente sqlite3_exec(). Dato che il dato estratto è un blob, non so come muovermi. Mi stavo orientando sul "readBlob()" dell'altro ESEMPIO.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 20:27   #9
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Bene, me lo sono studiato e ho scritto del codice:

Codice:
ostringstream oss;
	int aNumber = getItemRandomNumber();
	oss << aNumber;
	string number = oss.str();
	string aQuery = "SELECT image FROM items WHERE number = " + number + ";";
	unsigned char** ptrPicture; 
	int* ptrPictureSize; 
	const char* bQuery = &aQuery[0]; 
	sqlite3_stmt* pStmt; 
	int rc; 
	const char* ptrValue = &oss.str()[0];



	do {
		rc = sqlite3_prepare(databaseConnection, bQuery, -1, &pStmt, 0);
		if (rc != SQLITE_OK) {
			cerr << "error by sqlite3_prepare";
		}

		sqlite3_bind_text(pStmt, 1, ptrValue, -1, SQLITE_STATIC);

		rc = sqlite3_step(pStmt);
		if (rc == SQLITE_ROW) {
			
			*ptrPictureSize = sqlite3_column_bytes(pStmt, 0);
			*ptrPicture = (unsigned char *) malloc(*ptrPictureSize);
			memcpy(*ptrPicture, sqlite3_column_blob(pStmt, 0), *ptrPictureSize);
		}


		rc = sqlite3_finalize(pStmt);


	} while (rc == SQLITE_SCHEMA);
Però se avvio, non succede nulla, come se andasse in crash. Per fare dei test ho messo dei "cout <<" sparsi per il codice e sono arrivato alla conclusione ch eil problema sta nelle righe segnalate in rosso. In effetti se le "commento", il codice viene eseguito tutto, ovviamnete senza l'assegnazione al puntatore.
Idee?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2011, 23:43   #10
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Dopo altre 3 ore sono arrivato a fare qualche modifica:

Codice:
ostringstream oss;
	int aNumber = getItemRandomNumber();
	oss << aNumber;
	string number = oss.str();
	string aQuery = "SELECT image FROM items WHERE number = " + number + ";";
	FILE* ptrPicture; 
	int* ptrPictureSize; 
	const char* bQuery = &aQuery[0]; 
	sqlite3_stmt* pStmt; 
	int rc;
	const char* ptrValue = "newfile.jpg"; 


	do {
		rc = sqlite3_prepare(databaseConnection, bQuery, -1, &pStmt, 0);
		if (rc != SQLITE_OK) {
			cerr << "error by sqlite3_prepare in getRandomItem";
		}

		sqlite3_bind_blob(pStmt, 1, ptrValue, -1, SQLITE_STATIC);

		rc = sqlite3_step(pStmt);
		if (rc == SQLITE_ROW) {
		
			*ptrPictureSize = sqlite3_column_bytes(pStmt, 0);
			ptrPicture = (FILE*) malloc(*ptrPictureSize);
			memcpy(ptrPicture, sqlite3_column_blob(pStmt, 0), *ptrPictureSize);

		}

	
		rc = sqlite3_finalize(pStmt);

		
	} while (rc == SQLITE_SCHEMA);

Ora se lancio, non da errori e non va in crash. La mia domanda... Come faccio a vedere se veramente mi prende l'immagine dal DB e mi crea l'oggetto di tipo FILE?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2011, 22:56   #11
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
FINALMENTE penso di aver capito. Ho scritto il seguente metodo:

Codice:
Item* Database::getRandomItem() { //TODO

	//getting a random number from the table items
	int aNumber = getRandomNumber("items");
	string number;

	//converting the random number to a string
	{
		ostringstream oss;
		oss << aNumber;
		number = oss.str();
	}

	//getting the name price and happiness value from
	//the table itemns, accordingly to the random number
	//and converting the price and hapiness to int
	string aQuery =
			"SELECT name, price, happiness, image, filename FROM items WHERE number = "
					+ number + ";";
	sqlite3_stmt *pStmt;

	char* ptAQuery = &aQuery[0];
	if (sqlite3_prepare_v2(databaseConnection, ptAQuery, -1, &pStmt, 0)
			!= SQLITE_OK) {
		cerr << "db error (preparev2 in getRandomItem): " << sqlite3_errmsg(
				databaseConnection) << endl;
	}
	if (sqlite3_step(pStmt) != SQLITE_ROW) {
		cerr << "db error (step in getRandomItem): " << sqlite3_errmsg(
				databaseConnection) << endl;
	}

	const unsigned char* ptName = sqlite3_column_text(pStmt, 0);
	char* ptNameChar = (char*) ptName;
	string nameString = ptNameChar;

	int price = sqlite3_column_int(pStmt, 1);

	int happiness = sqlite3_column_int(pStmt, 2);

	int imageSize = sqlite3_column_bytes(pStmt, 3);

	FILE* ptImage = (FILE*) malloc(imageSize);
	memcpy(ptImage, sqlite3_column_blob(pStmt, 3), imageSize);

	const unsigned char* ptFilename = sqlite3_column_text(pStmt, 4);
	char* ptFilenameChar = (char*) ptFilename;
	string filenameString = ptFilenameChar;

        sqlite3_finalize(pStmt);

	return new Item(filenameString, price, happiness, ptImage);

}

Ora ho due dubbi:
1. dato che ptImage è un puntatore, una volta che uso sqlite3_finalize(pStmt); il puntatore perde il valore, o grazie a malloc e memcpy resta?
2. come faccio a testare se fuzniona?
Chiedo "gentilmente" due risposte
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 00:25   #12
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Ora ho due dubbi:
1. dato che ptImage è un puntatore, una volta che uso sqlite3_finalize(pStmt); il puntatore perde il valore, o grazie a malloc e memcpy resta?
2. come faccio a testare se fuzniona?
Chiedo "gentilmente" due risposte
Risposte rapide:
1) Non funzionerà certamente perchè stai cercando di allocare tramite malloc un FILE, operazione che è destinata miseramente a fallire, dovresti invece allocare un buffer.
2)Un debugger?

Una osservazione: quando copi il risultato di sqlite3_column_text in una stringa non hai bisogno di effettuare tutti quei passaggi:
Codice:
string nameString((const char*)sqlite3_column_text(pStmt, 0));
Infine hai eseguito una malloc senza la relativa free...
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 08:40   #13
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
che potevo scrivere direttamente string non lo sapevo, pensavo di dover fare le conversioni. Grazie per l'osservazione.
Che dovevo "liberare" dopo malloc lo sapevo, ma me ne sono scordato. Per il fatto del buffer...non ho idea di come fare. Hai voglia si spiegarmi?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 11:03   #14
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
che potevo scrivere direttamente string non lo sapevo, pensavo di dover fare le conversioni. Grazie per l'osservazione.
Che dovevo "liberare" dopo malloc lo sapevo, ma me ne sono scordato. Per il fatto del buffer...non ho idea di come fare. Hai voglia si spiegarmi?
Io preferisco usare vector così mi evito di dover gestire la memoria a mano
Codice:
vector<unsinged char>ptImage(imageSize);
memcpy(&ptImage[0], sqlite3_column_blob(pStmt, 3), imageSize);
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 11:35   #15
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Io preferisco usare vector così mi evito di dover gestire la memoria a mano
...non ho capito.
Non manca qualcosa?
Codice:
vector<unsinged char>ptImage(imageSize);
?
__________________
Vendo...nulla.
Cerco...la felicità
.

Ultima modifica di Emaborsa : 21-04-2011 alle 11:38.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 13:49   #16
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
1) Non funzionerà certamente perchè stai cercando di allocare tramite malloc un FILE, operazione che è destinata miseramente a fallire, dovresti invece allocare un buffer.
Mi spieghi anche questa? Se leggo QUI tice che posso fare il cast "to the desired type".
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 21:30   #17
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
...non ho capito.
Non manca qualcosa?
Codice:
vector<unsinged char>ptImage(imageSize);
?
Cosa dovrebbe mancare?
Forse il namespace std se non hai dichiarato lo using prima e ovviamente l'include dell'header vector:
Codice:
#include <vector>
...
std::vector<unsinged char>ptImage(imageSize);
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 21:33   #18
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Mi spieghi anche questa? Se leggo QUI tice che posso fare il cast "to the desired type".
Si però FILE è un "oggetto" non un array.
Contiene informazioni riguardanti uno stream di dati e deve essere istanziato ed elaborato da funzioni presenti in cstdio.h.
Non hai modo programmaticamente di istanziare correttamente tutte le strutture dati interne all' "oggetto" FILE, nè tanto meno può farlo malloc, che semplicemente riserva un'area di memoria.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 21:48   #19
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Cosa dovrebbe mancare?
Forse il namespace std se non hai dichiarato lo using prima e ovviamente l'include dell'header vector:
Codice:
#include <vector>
...
std::vector<unsinged char>ptImage(imageSize);
...boh, non la capisco. Saranno le mie scarse conoscenze di C++.


Quote:
Originariamente inviato da tomminno Guarda i messaggi
Si però FILE è un "oggetto" non un array.
Contiene informazioni riguardanti uno stream di dati e deve essere istanziato ed elaborato da funzioni presenti in cstdio.h.
Non hai modo programmaticamente di istanziare correttamente tutte le strutture dati interne all' "oggetto" FILE, nè tanto meno può farlo malloc, che semplicemente riserva un'area di memoria.
ok, capito....allora come faccio? ok posso fare il cast in un char*, ma poi con quello cosa ci faccio? Al momento ho questo codice:

Codice:
char* ptImage = (char*) malloc(imageSize);

	memcpy(ptImage, sqlite3_column_blob(pStmt, 3), imageSize);

	const unsigned char* ptFilename = sqlite3_column_text(pStmt, 4);
	const char* ptFilenameChar = (const char*) ptFilename;
	ofstream outfile (ptFilenameChar,ofstream::binary);
	outfile.write (ptImage,imageSize);
Questo l'ho fatto per vedere se il codice è OK, e in effetti funziona, dato che mi crea il jpg su disco fisso. Io però ho bisogno dell'oggetto FILE*. C'è un modo per farlo o devo scrivere sul disco (come attualmente fa) e poi aprirlo con fopen?
__________________
Vendo...nulla.
Cerco...la felicità
.

Ultima modifica di Emaborsa : 21-04-2011 alle 22:24.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2011, 23:02   #20
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
...boh, non la capisco. Saranno le mie scarse conoscenze di C++.
Semplicemente quel codice costruisce un oggetto vettore di unsigned char (è uguale anche usando char) ampio imageSize.
Il vantaggio di vector è che è compatibile con gli array del C.

Quote:
ok, capito....allora come faccio? ok posso fare il cast in un char*, ma poi con quello cosa ci faccio? Al momento ho questo codice:

Codice:
char* ptImage = (char*) malloc(imageSize);

	memcpy(ptImage, sqlite3_column_blob(pStmt, 3), imageSize);

	const unsigned char* ptFilename = sqlite3_column_text(pStmt, 4);
	const char* ptFilenameChar = (const char*) ptFilename;
	ofstream outfile (ptFilenameChar,ofstream::binary);
	outfile.write (ptImage,imageSize);
Questo l'ho fatto per vedere se il codice è OK, e in effetti funziona, dato che mi crea il jpg su disco fisso. Io però ho bisogno dell'oggetto FILE*. C'è un modo per farlo o devo scrivere sul disco (come attualmente fa) e poi aprirlo con fopen?
Perchè vuoi proprio farti del male utilizzando FILE*?
In tal caso devi usare le funzioni di io su file del C al posto di ofstream tipo:
Codice:
FILE * fp = fopen(ptFilenameChar, "wb");
fwrite (ptImage, 1 , imageSize , fp );
...
fclose(fp);
tomminno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
La capsula SpaceX Dragon CRS-33 ha acces...
La NASA è sempre più vicin...
Crisi delle memorie: ASUS torna al passa...
Le console next-generation potrebbero es...
Gemini cresce ancora: la quota di mercat...
Samsung sfida TSMC: la capacità produtti...
Iliad alza il prezzo della fibra ottica ...
Il prossimo low cost di POCO sarà il più...
The Elder Scrolls VI: ecco le ultime sul...
Ecco i saldi di fine anno Amazon, 34 off...
iPhone Fold: scorte limitate al lancio m...
OpenAI porterà la pubblicità in ChatGPT ...
TSMC aumenterà ancora i prezzi: nel 2026...
Marvel pubblica anche il secondo teaser ...
Nuovo accordo tra xAI e il Pentagono: l'...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 08:02.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v