利用資料集在水晶報表中顯示映像的 .NET 程式教程

來源:互聯網
上載者:User
程式|教程|資料|水晶報表|顯示 目錄

描述
檔案清單
步驟
Form1.cs
VB.NET 版


描述

該 C# .NET Windows 程式示範了如何建立資料集,並將映像添加到資料集,以及在運行時將資料集傳遞到子報表。


檔案清單

- bin\Debug\Canada.jpg
- bin\Debug\Germany.jpg
- bin\Debug\Japan.jpg
- bin\Debug\USA.jpg
- App.ico
- AssemblyInfo.cs
- CrystalReport1.cs
- CrystalReport1.rpt
- DynamicImage.csproj
- DynamicImage.csproj.user
- DynamicImage.sln
- Form1.cs
- Form1.resx
- Readme.txt
- Steps.txt


步驟

* 開始一個新項目/建立資料集及其模式

- 建立項目
- 轉到 Form1.cs 後置的代碼
- Imports System.Data/System.IO
- 建立函數 "CreateData",以建立資料集:

DataSet CreateData()
{
DataSet data = new DataSet();
data.Tables.Add("Images");
data.Tables[0].Columns.Add("Country", System.Type.GetType("System.String"));
data.Tables[0].Columns.Add("img", System.Type.GetType("System.Byte[]"));
data.WriteXmlSchema(Directory.GetCurrentDirectory() + "\\DynamicImage.xsd");
}

- 建立函數 "CreateReport",以調用 CreateData 建立資料集模式:

void CreateReport()
{
CreateData();
}

- 在建構函式中調用 CreateReport

public Form1()
{
//
// Required for Windows Form Designer support
//
InitializeComponent();

//
// TODO: Add any constructor code after InitializeComponent call
//
CreateReport();
}

- 構造並執行程式/將在 Bin\Debug 檔案夾中建立 DynamicImage.xsd。


* 設計報表

- 項目->添加新項
- 選擇 Crystal Report,並單擊“開啟”
- 選擇“作為空白報表”,並單擊“確定”
- 右擊任意空白處,選擇“資料庫->添加/刪除資料庫”
- 展開 ODBC (RDO),選擇 Xtreme Sample Database,並單擊“完成”。
- 展開表,雙擊 Customer
- 單擊“確定”
- 將 Customer Name 和 Last Year's Sales 拖放到詳細資料
- 右擊任意空白處,插入->子報表
- 將子報表放置在 Last Year's Sales 旁邊
- 選擇“建立子報表”,並將子報表命名為 "Flags",單擊“報表專家”
- 擴充“更多資料來源”,選擇 ADO.NET (XML)
- 找到 DynamicImage.xsd,並單擊“完成”
- 雙擊 Images
- 單擊“下一步”,雙擊 img,單擊“完成”
- 單擊“連結”選項卡
- 雙擊 Country,並單擊“確定”
- 調整子報表的大小
- 在子報表上雙擊,以開啟子報表
- 刪除報表首 b 和報表尾 b
- 右擊 -> 關閉子報表


* 回到代碼,並編寫 Crystal 代碼

- 將 CrystalReportViewer 控制項拖放到表單 Form1
- 選擇 CrystalReportViewer1,F4(屬性)
- 改變 Dock 屬性,填充
- 查看代碼
- 注釋掉 WriteXmlSchema(因為只在設計報表時需要資料集模式檔案)
- 在 CreateData 函數中組裝資料集,並將其返回

void AddImageRow(DataTable tbl, string name, string filename)
{
FileStream fs = new FileStream(filename, FileMode.Open);
BinaryReader br = new BinaryReader(fs);
DataRow row;
row = tbl.NewRow();
row[0] = name;
row[1] = br.ReadBytes((int)br.BaseStream.Length);
tbl.Rows.Add(row);
br = null;
fs = null;
}

DataSet CreateData()
{
DataSet data = new DataSet();
data.Tables.Add("Images");
data.Tables[0].Columns.Add("Country", System.Type.GetType("System.String"));
data.Tables[0].Columns.Add("img", System.Type.GetType("System.Byte[]"));
//data.WriteXmlSchema(Directory.GetCurrentDirectory() + "\\DynamicImage.xsd");
AddImageRow(data.Tables[0], "USA", Directory.GetCurrentDirectory() + "\\USA.jpg");
AddImageRow(data.Tables[0], "Canada", Directory.GetCurrentDirectory() + "\\Canada.jpg");
AddImageRow(data.Tables[0], "Germany", Directory.GetCurrentDirectory() + "\\Germany.jpg");
AddImageRow(data.Tables[0], "Japan", Directory.GetCurrentDirectory() + "\\Japan.jpg");
return (data);
}


- 建立報表文檔,將資料集傳遞到子報表,並將報表綁定到水晶報表檢視器:

void CreateReport()
{
CrystalReport1 cr = new CrystalReport1();
cr.OpenSubreport("Flags").SetDataSource(CreateData());
crystalReportViewer1.ReportSource = cr;
}



Form1.cs

using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.IO;

namespace DynamicImage
{
/// <summary>
/// Summary description for Form1.
/// </summary>
public class Form1 : System.Windows.Forms.Form
{
private CrystalDecisions.Windows.Forms.CrystalReportViewer crystalReportViewer1;
/// <summary>
/// Required designer variable.
/// </summary>
private System.ComponentModel.Container components = null;

// 過程: AddImageRow
// 讀取影像檔,並將其添加到資料集的表中
//
// [in] tbl 資料表
// country 國家名
// filename 映像的檔案名稱
//
void AddImageRow(DataTable tbl, string name, string filename)
{
FileStream fs = new FileStream(filename, FileMode.Open); // 建立檔案流
BinaryReader br = new BinaryReader(fs); // 建立二進位讀取器
DataRow row;

// 建立一個新的資料行
row = tbl.NewRow();

// 設定 country 欄位和 image 欄位
row[0] = name;
row[1] = br.ReadBytes((int)br.BaseStream.Length);

// 將資料行添加到表中
tbl.Rows.Add(row);

// 清除
br = null;
fs = null;
}

// 函數: CreateData
// 建立資料集,包含一個表,表有兩個欄位:Country (string), 和 img (blob/byte[])
// 為表添加四條記錄
//
DataSet CreateData()
{
DataSet data = new DataSet();

// 將表 'Images' 添加到資料集
data.Tables.Add("Images");

// 添加兩個欄位
data.Tables[0].Columns.Add("Country", System.Type.GetType("System.String"));
data.Tables[0].Columns.Add("img", System.Type.GetType("System.Byte[]"));

// 建立資料集模式(該模式用於設計報表)
// 報表建立以後,不再需要模式檔案
//data.WriteXmlSchema(Directory.GetCurrentDirectory() + "\\DynamicImage.xsd");

// 添加四行
AddImageRow(data.Tables[0], "USA", Directory.GetCurrentDirectory() + "\\USA.jpg");
AddImageRow(data.Tables[0], "Canada", Directory.GetCurrentDirectory() + "\\Canada.jpg");
AddImageRow(data.Tables[0], "Germany", Directory.GetCurrentDirectory() + "\\Germany.jpg");
AddImageRow(data.Tables[0], "Japan", Directory.GetCurrentDirectory() + "\\Japan.jpg");

return (data);
}

// 過程: CreateReport
// 建立報表,並傳遞資料集
//
void CreateReport()
{
// 建立報表
CrystalReport1 cr = new CrystalReport1();

// 將資料集(通過調用函數 CreateData 建立的)傳遞到子報表 "Flags"
cr.OpenSubreport("Flags").SetDataSource(CreateData());

// 將報表文檔傳遞到查看器
crystalReportViewer1.ReportSource = cr;
}

public Form1()
{
//
// Required for Windows Form Designer support
//
InitializeComponent();

//
// TODO: Add any constructor code after InitializeComponent call
//
CreateReport();
}

後面的部分省略……



相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。