Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
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


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
E-mail reset password di Instagram: la c...
La NASA ha discusso le problematiche del...
Il razzo spaziale NASA SLS e la capsula ...
Stazione Spaziale Internazionale: Crew-1...
Samsung Galaxy S26 Ultra: la ricarica de...
Apple ha un nuovo partner per la sua App...
Trenitalia introduce il prezzo dinamico ...
OnePlus non si ferma più: c'&egra...
DAZN sconta il piano Full per 6 mesi, se...
L'uso dell'IA nei giochi è cancer...
Meta punta sul nucleare USA per alimenta...
Le migliori offerte Amazon del weekend: ...
La crisi dell'hardware spinge i negozi g...
Apple Watch SE 3 scontato su Amazon: il ...
Robot aspirapolvere davvero scontati: si...
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: 01:56.


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