| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 
 | void Fenetre::recupInfo(ifstream& fimages, std::string& nom, ImageInfo::cote& dr, ImageInfo::cote& gche, ImageInfo::cote& ht, ImageInfo::cote& ba)
{
	getline(fimages,nom);cout << nom;
	int v;
	fimages >> v; cout << v; dr=ImageInfo::int2Cote(v);
	fimages >> v; cout << v; gche=ImageInfo::int2Cote(v);
	fimages >> v; cout << v; ht=ImageInfo::int2Cote(v);
	fimages >> v; cout << v; ba=ImageInfo::int2Cote(v);
}
 
bool Fenetre::lectureFichierDeConf()
{
	// récupération des images
	ifstream fimages(Fenetre::fichierImages.c_str());
	long debut=fimages.tellg();
	bool err=false;
	if (!fimages.fail())
	{
		// on compte le nombre de lignes = le nombre d'images
		string ligne;
		while(getline(fimages,ligne))
			nbImages++;
		fimages.seekg(debut,ios_base::beg);
 
		// On alloue
		if (nbImages>0)
		{
			try 
			{
				images=new ImageInfo[nbImages];
			}
			catch(std::bad_alloc&)
			{
				cout << "Erreur d'allocation" << endl;
			}
		}
		fimages.close();
	}
 
	fimages.open(Fenetre::fichierImages.c_str());
	if (!fimages.fail())
	{
		// On charge les images
		int i=0;
		string nom;
		ImageInfo::cote dr, gche, ht, bas;
		while(!fimages.eof())
		{
			recupInfo(fimages,nom,dr,gche,ht,bas);
			//images[i++].set(nom);
			nom.erase();
		}
		fimages.close();
		err=true;
	}
 
	return err;
} | 
Partager