Oltețeanu Bogdan-Andrei

Unele lucruri nu se explică.

Crystal Reports – Rapoarte multiple

leave a comment

La un moment dat a trebuit sa ma lupt cu o problema aparent usoara la inceput dar care a degenerat pe masura ce incercam solutii si solutii. Scenariul arata cam asa:

  • Se da un numar de rapoarte folosite ca Embedded Resource.
  • Utilizatorul trebuie sa aibe optiunea de a le printa / vizualiza pe toate.
  • Se da o tabela care contine numele raportului(cel din proiect), descrierea lui, si firma de care apartine.

Eu trebuia sa selectez anumite nume de rapoarte din tabela, sa le regasesc in proiectul meu dupa care sa le afisez/printez.

Problema nr1:

Cum regasesc si folosesc raportul meu in viewer in functie de numele lui din tabela?

Dupa multe sapaturi am hotarat ca solutia cea mai buna era sa imi salvez fiecare document pe disc dupa care sa-l incarc in Viewer iar apoi sa-l sterg.

Metoda pentru a-l scrie pe disc:


private void LoadReportToFile(string nameOfTemplateFile, string pathToDest)
{
System.IO.FileInfo fi = new System.IO.FileInfo(pathToDest);
if (fi.Exists) fi.Delete();
System.Reflection.Assembly asm = System.Reflection.Assembly.GetExecutingAssembly();
foreach (string str in asm.GetManifestResourceNames())
{
if (str.ToLower().IndexOf(nameOfTemplateFile.ToLower()) > -1) nameOfTemplateFile = str;
}
System.IO.Stream file = asm.GetManifestResourceStream(nameOfTemplateFile);
System.IO.FileStream outFile = new System.IO.FileStream(pathToDest, System.IO.FileMode.Create);
int bufferLen = 1024;
byte[] buffer = new byte[bufferLen];
int bytesRead;
do
{
bytesRead = file.Read(buffer, 0, bufferLen);
outFile.Write(buffer, 0, bytesRead);
} while (bytesRead != 0);
outFile.Close();
outFile.Dispose();
}

Mai departe aveam un combobox care tinea selectul meu din tabela cu numele exact al raportului. Daca aveam un raport cu numele rptRaportFirma.rpt in tabela era trecut ca rptRaportFirma drept urmare m-am folosit de combobox pentru a chema functia LoadReportToFile();
Cu urmatorul cod cand selectam un raport din combobox era incarcat automat in preview.


private void cbReports_SelectedIndexChanged(object sender, EventArgs e)
{

................

String rptPath = "Reports." + cbReports.Text;
String pathToSave = Variabile.ReportTemplatePath;//cale definita global
LoadReportToFile(rptPath, pathToSave);

//aici eliberam memoria de rapoarte incarcate precedent

if (Rpt != null)
{
Rpt.Close();
Rpt.Dispose();
}

Rpt = new CrystalDecisions.CrystalReports.Engine.ReportDocument();
Rpt.Load(pathToSave);

//stergem raportul generat
DeleteReportFile(pathToTemplateFile);

Rpt.SetDataSource(rptdataSet);

rptViewer.ReportSource = Rpt;
}

Problema nr2:

Cand incercam sa automatizez procesul de printare a peste 100-200 de rapoarte am aflat ca Crystal Reports are o anumita limita care se reflecta prin urmatoarea eroare :

“The maximum report processing jobs limit configured by your system administrator has been reached

Una din solutii a fost sa modific o anumita cheie in registry pentru a scoate aceasta limitare si anume

HKEY_LOCAL_MACHINE\SOFTWARE\CRYSTAL DECISIONS\10.0\REPORT APPLICATION SERVER\SERVER\PrintJobLimit

pentru versiunea 10.0 dar din pacate e inacceptabil sa modific pe fiecare statie registrii asa ca am ales urmatoarea metoda:


..................

String rptPath = "Reports." + lbDepartureDocuments.GetItemValue(id).ToString();
LoadReportToFile(rptPath, Variabile.ReportTemplatePrintPath);
ReportDocument Rpt = new ReportDocument();
Rpt.Load(Variabile.ReportTemplatePrintPath);
Rpt.SetDataSource(rptdataSet);
Rpt.PrintToPrinter(1, false, 0, 0);
DeleteReportFile(Variabile.ReportTemplatePrintPath);
//Eliberam fortat resursele folosite de raport pentru a nu ajunge la limita impusa de Crystal Reports:
Rpt.Close();
Rpt.Dispose();

..................

Poate aceste lucruri mai ajuta pe cineva la fel de incepator ca mine happy

Written by andy

November 23rd, 2009 at 12:07 pm

Posted in Development

Tagged with , ,

Leave a Reply