On this post, you will learn how to create a basic chart on Windows Form Application with VB.NET. I use Microsoft Visual Studio 2005 as IDE.
Requirement
Step-by-step
- Install the requirement software as stated on the Requirement section.
- Open Microsoft Visual Studio 2005. Create a new VB.NET’s Windows Application. Type the name of the project as “SampleBasicChart“.
data:image/s3,"s3://crabby-images/a77c4/a77c40f1496058a2242013e5990bd758f193da88" alt="Create Windows Application's Project Create Windows Application's Project"
- On Toolbox window, drag a Chart control from the Data category to the Windows Form.
data:image/s3,"s3://crabby-images/56fb1/56fb10206985741cd614f50d6259d9ef4a8c2ccd" alt="A Chart Control A Chart Control"
Note: If you does not see the Chart control in the Toolbox, you need to perform these steps below: - Right-click on the Toolbox window and select Choose Items.
data:image/s3,"s3://crabby-images/b1089/b1089568da3d77ab041908b52ede5c8dc3059a9e" alt="Add New Item to Toolbox Add New Item to Toolbox"
- On Choose Toolbox Items, click Browse.
data:image/s3,"s3://crabby-images/710c0/710c031bb0feb5fd6bf40e7d718ee8b1ea38b6bc" alt="Browse the Component Browse the Component"
- Browse to the location where you have installed Microsoft Chart Controls. The default location is
C:\Program Files\Microsoft Chart Controls\Assemblies and select System.Windows.Forms.DataVisualization.dll. Then, click Open.
data:image/s3,"s3://crabby-images/30d9e/30d9e71dc4a152f23f1661ddd3310e0840d5149c" alt="System.Windows.Forms.DataVisualization.dll System.Windows.Forms.DataVisualization.dll"
- You see Chart control has been added to .NET Framework Components. Verify that its check box is checked and click OK.
data:image/s3,"s3://crabby-images/32c72/32c7243f3531c870f13bfb9860285db60ac049af" alt="Chat Control Component Chat Control Component"
- On Chart Properties, you see an empty chart with a default series, “Series1“. Next, I’m going to add another Series. On Chart Properties, click the Series collection. Then, click the ellipsis button.
data:image/s3,"s3://crabby-images/ddd98/ddd9881031e617beb1604570f409a69812d9c497" alt="Chart Properties Chart Properties"
- On Series Collection Editor, click Add. You will see “Series2” has been added to the collection.
data:image/s3,"s3://crabby-images/00980/00980e62c28dbab15c56b45d4688f819268b13a2" alt="Series Collection Editor Series Collection Editor"
- Now you have two series on a chart. But there is not any data on the chart so I will add some example data point on each series. Select Series1 and click the ellipsis button on Points collection.
- On Series Collection Editor, select “Series1” in the Members area and click the Points collection property. Then, click the ellipsis button.
data:image/s3,"s3://crabby-images/9ab2a/9ab2a23f79499ac6c8676994f0e2d85301436aa1" alt="Add Data Points Add Data Points"
- On DataPoint Collection Editor, click Add and assign a value “10” to the YValues property in the newly created DataPoint object.
data:image/s3,"s3://crabby-images/e14a8/e14a8db5d31708270924880206efbe605fef4a50" alt="Set YValues on DataPoint Set YValues on DataPoint"
- Repeat step 8 to add two more DataPoint object with values “20” and “30” repectively. Then, click OK to close the DataPoint Collection Editor window.
Note: These values are example values, you may use any value as you want.
- Repeat step 7-9 again on “Series2” with YValues as you want. Then, click OK to close the Series Collection Editor windows.
- Run the project. You see the chart with two series as you created.
data:image/s3,"s3://crabby-images/58e0d/58e0d844b6631515b87b494025d4137ff0fb46ac" alt="A Basic Chart A Basic Chart"
Sample chart
The sample chart that I use on this post has a series “Series1” which has 3 data points “10,20,30“.
data:image/s3,"s3://crabby-images/eddb3/eddb385924e91c87ebf4738a0f09117a56286b0e" alt="Sample chart Sample chart"
Back to top
Change chart type
There are many chart types that you can select for Chart control. On this example, I show some of those chart types which are Point, Line, Bar, Pie.
- On Chart Properties, click the Series collection. Then, click the ellipsis button.
data:image/s3,"s3://crabby-images/033de/033de601d76d5b652c50a7d898c9c3abfddb405b" alt="Chart Properties Chart Properties"
- On Series Collection Editor, select “Series1” in the Members area and change the Chart type property to Point.
data:image/s3,"s3://crabby-images/ac0f5/ac0f590eaeae9198097090f0f57517d3d871c220" alt="Change Chart Type Change Chart Type"
- The Point chart type.
data:image/s3,"s3://crabby-images/1d144/1d144d4dee33278d8f9024879257324c3b1d5664" alt="Point Chart Point Chart"
- The Line chart type.
- The Bar chart type.
data:image/s3,"s3://crabby-images/47c8a/47c8a64660daeae15b1d65d84900982fa8e769e4" alt="Bar Chart Bar Chart"
- The Pie chart type.
data:image/s3,"s3://crabby-images/a480c/a480c71a3e612821a1ccaf78e799d0bf0873c512" alt="Pie Chart Pie Chart"
Back to top
Change Color style of chart
There are many color palettes that you can choose for Chart control. This section shows how to change color of Chart control.
- On Chart Properties, click on Palette property. You see a drop down button. Click on it and you can choose a color palette for your chart.
data:image/s3,"s3://crabby-images/d54a0/d54a00da237453e4536ec5865f2b3008a9f0a00f" alt="Change Color Palette Change Color Palette"
- The example below is Bright color palette.
Back to top
Insert title to chart
This section shows how to insert title to Chart control.
- On Chart Properties, click the Title collection. Then, click the ellipsis button.
data:image/s3,"s3://crabby-images/e1730/e1730a86cf086538e3fe2c384884be6b3c912941" alt="Chart Properties Chart Properties"
- On Title Collection Editor, click Add and set (Text) to “My Sample Chart” in the newly created Title object.
data:image/s3,"s3://crabby-images/c7e5f/c7e5fc26e82f00a44c278e5b85792f49165d2ee1" alt="Add Title Add Title"
- Run the project. You will see a title on top of the chart.
data:image/s3,"s3://crabby-images/89f07/89f076d8585aa144e1f045eb3108badbd651cbed" alt="Sample Chart with title Sample Chart with title"
- You can customize title’s text style, title position, title color on title properties.
data:image/s3,"s3://crabby-images/6da0f/6da0fa132c894d081fdc9df80caf4ee951b21e5e" alt="Title Properties Title Properties"
Back to top
3D chart
This section shows how to use three-dimensional (3D) chart areas in Chart control.
- On Chart Properties, click the ChartAreas collection. Then, click the ellipsis button.
data:image/s3,"s3://crabby-images/38593/385930222e95e3b9c61b077adf7ad1b392f55cc3" alt="Open ChartArea Collection Editor Open ChartArea Collection Editor"
- On ChartArea Collection Editor, select “ChartArea1“. Expand Area3DStyle and change (Enable3D) to True.
Note: You can customize your 3D Style on this Area3DStyle properties .
data:image/s3,"s3://crabby-images/3da35/3da35a026d916dba4a1aed1f3d7f8cf40fa72ccf" alt="Enable 3D Chart Enable 3D Chart"
- You see the chart is now 3D.
data:image/s3,"s3://crabby-images/4ea4b/4ea4bd49690d596ec101aee96d6bcb2ab070e94f" alt="Sample 3D Chart Sample 3D Chart"
Step-by-step
- Create a new Windows Application project on VB.NET and type name as “SampleDataBindChart“.
data:image/s3,"s3://crabby-images/441ea/441ea4b35f7fb6b0172d92e208290351bdaccb5a" alt="Create New VB.NET's Windows Application Create New VB.NET's Windows Application"
- On Form1, open code window and import these libraries. The first two libraries are used for SQL. The last one is used for Chart.
Imports System.Data
Imports System.Data.SqlClient
Imports System.Windows.Forms.DataVisualization.Charting
- Type code below on Form1_Load().
1
2
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 | Dim strConn As String = "Data Source=BKKSQL001\INSTANCE01;" & _
"Initial Catalog=Northwind;Integrated Security=True"
Dim conn As New SqlConnection(strConn)
Dim sqlProducts As String = "SELECT Top 8 ProductName, UnitsInStock FROM Products"
Dim da As New SqlDataAdapter(sqlProducts, conn)
Dim ds As New DataSet()
da.Fill(ds, "Products")
Dim ChartArea1 As ChartArea = New ChartArea()
Dim Legend1 As Legend = New Legend()
Dim Series1 As Series = New Series()
Dim Chart1 = New Chart()
Me.Controls.Add(Chart1)
ChartArea1.Name = "ChartArea1"
Chart1.ChartAreas.Add(ChartArea1)
Legend1.Name = "Legend1"
Chart1.Legends.Add(Legend1)
Chart1.Location = New System.Drawing.Point(13, 13)
Chart1.Name = "Chart1"
Series1.ChartArea = "ChartArea1"
Series1.Legend = "Legend1"
Series1.Name = "Series1"
Chart1.Series.Add(Series1)
Chart1.Size = New System.Drawing.Size(800, 400)
Chart1.TabIndex = 0
Chart1.Text = "Chart1"
Chart1.Series("Series1").XValueMember = "ProductName"
Chart1.Series("Series1").YValueMembers = "UnitsInStock"
Chart1.DataSource = ds.Tables("Products") |
Code Explanation:
- Line 1-2: Define a connection string to connect to a database on SQL Server.
- Data Source is a SQL Server name.
- Initial Catalog is a database name.
- Set Integrated Security=True to use the current user as identity to access the SQL Server database.
- Line 4: Create a SqlConnection’s object.
- Line 6: Define SQL query string.
- Line 7-9: Execute the query and populate result to DataSet’s object.
- Line 11-14: Create Chart’s objects.
- Line 15: Add Chart’s object to the form.
- Line 17-29: Set Chart’s properties (ChartArea, Legend and Series).
- Line 31-32: Bind column “ProductName” to X-axis and column “UnitsInStock” to Y-axis on the “Series1” Chart.
- Line 34: Set Chart’s data source to the DataTable in the DataSet’s object.
- Run the project. You see a chart displaying “Product Name” on X-axis and “Unit in Stock” on Y-axis which data is gathered from Northwind database on SQL Server.
data:image/s3,"s3://crabby-images/6b6a4/6b6a4c639b0437fab2bd75ed69891cc36edfcb43" alt="A chart binding to Database on SQL Server A chart binding to Database on SQL Server"
Tidak ada komentar:
Posting Komentar