WPF、Silverlight項目中使用柱狀圖、餅狀圖、折線圖,去水印版及去掉“You are using the trial version”的方法

轉自:請參考:http://www.cnblogs.com/sunyjie/p/3410851.html

在開發的過程中,可能會遇到柱狀圖、餅狀圖、折線圖來更好的顯示數據,最近整理了一下,遂放出來望需要的朋友可以參考。本文僅僅是簡單顯示,如需複雜顯示效果請參考官網代碼示例。----本文代碼使用WPF,Silverlight類似代碼,使用第三方wpf_visifire_v5.1.2-0_trial控件。

後續會放上Html5示例。

代碼下載地址:代碼下載

 

先放上一組截圖吧:

image

image

image

公共數據:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

private List<string> strListx = new List<string>() { "蘋果""櫻桃""菠蘿""香蕉""榴蓮""葡萄""桃子""獼猴桃" };

        private List<string> strListy = new List<string>() { "13""75""60""38""97""22""39""80" };

 

        private List<DateTime> LsTime = new List<DateTime>()

            {

               new DateTime(2012,1,1),

               new DateTime(2012,2,1),

               new DateTime(2012,3,1),

               new DateTime(2012,4,1),

               new DateTime(2012,5,1),

               new DateTime(2012,6,1),

               new DateTime(2012,7,1),

               new DateTime(2012,8,1),

               new DateTime(2012,9,1),

               new DateTime(2012,10,1),

               new DateTime(2012,11,1),

               new DateTime(2012,12,1),

            };

        private List<string> cherry = new List<string>() { "33""75""60""98""67""88""39""45""13""22""45""80" };

        private List<string> pineapple = new List<string>() { "13""34""38""12""45""76""36""80""97""22""76""39" };


 

  柱狀圖:

複製代碼

public void CreateChartColumn(string name, List<string> valuex, List<string> valuey)
        {
            //創建一個圖標
            Chart chart = new Chart();

            //設置圖標的寬度和高度
            chart.Width = 580;
            chart.Height = 380;
            chart.Margin = new Thickness(100, 5, 10, 5);
            //是否啓用打印和保持圖片
            chart.ToolBarEnabled = false;

            //設置圖標的屬性
            chart.ScrollingEnabled = false;//是否啓用或禁用滾動
            chart.View3D = true;//3D效果顯示

            //創建一個標題的對象
            Title title = new Title();

            //設置標題的名稱
            title.Text = Name;
            title.Padding = new Thickness(0, 10, 5, 0);

            //向圖標添加標題
            chart.Titles.Add(title);

            Axis yAxis = new Axis();
            //設置圖標中Y軸的最小值永遠爲0           
            yAxis.AxisMinimum = 0;
            //設置圖表中Y軸的後綴          
            yAxis.Suffix = "斤";
            chart.AxesY.Add(yAxis);

            // 創建一個新的數據線。               
            DataSeries dataSeries = new DataSeries();

            // 設置數據線的格式
            dataSeries.RenderAs = RenderAs.StackedColumn;//柱狀Stacked


            // 設置數據點              
            DataPoint dataPoint;
            for (int i = 0; i < valuex.Count; i++)
            {
                // 創建一個數據點的實例。                   
                dataPoint = new DataPoint();
                // 設置X軸點                    
                dataPoint.AxisXLabel = valuex[i];
                //設置Y軸點                   
                dataPoint.YValue = double.Parse(valuey[i]);
                //添加一個點擊事件        
                dataPoint.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);
                //添加數據點                   
                dataSeries.DataPoints.Add(dataPoint);
            }

            // 添加數據線到數據序列。                
            chart.Series.Add(dataSeries);

            //將生產的圖表增加到Grid,然後通過Grid添加到上層Grid.           
            Grid gr = new Grid();
            gr.Children.Add(chart);
            Simon.Children.Add(gr);
        }

複製代碼

  餅狀圖:

複製代碼

public void CreateChartPie(string name, List<string> valuex, List<string> valuey)
        {
            //創建一個圖標
            Chart chart = new Chart();

            //設置圖標的寬度和高度
            chart.Width = 580;
            chart.Height = 380;
            chart.Margin = new Thickness(100, 5, 10, 5);
            //是否啓用打印和保持圖片
            chart.ToolBarEnabled = false;

            //設置圖標的屬性
            chart.ScrollingEnabled = false;//是否啓用或禁用滾動
            chart.View3D = true;//3D效果顯示

            //創建一個標題的對象
            Title title = new Title();

            //設置標題的名稱
            title.Text = name;
            title.Padding = new Thickness(0, 10, 5, 0);

            //向圖標添加標題
            chart.Titles.Add(title);

            //Axis yAxis = new Axis();
            ////設置圖標中Y軸的最小值永遠爲0           
            //yAxis.AxisMinimum = 0;
            ////設置圖表中Y軸的後綴          
            //yAxis.Suffix = "斤";
            //chart.AxesY.Add(yAxis);

            // 創建一個新的數據線。               
            DataSeries dataSeries = new DataSeries();

            // 設置數據線的格式
            dataSeries.RenderAs = RenderAs.Pie;//柱狀Stacked


            // 設置數據點              
            DataPoint dataPoint;
            for (int i = 0; i < valuex.Count; i++)
            {
                // 創建一個數據點的實例。                   
                dataPoint = new DataPoint();
                // 設置X軸點                    
                dataPoint.AxisXLabel = valuex[i];

                dataPoint.LegendText = "##" + valuex[i];
                //設置Y軸點                   
                dataPoint.YValue = double.Parse(valuey[i]);
                //添加一個點擊事件        
                dataPoint.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);
                //添加數據點                   
                dataSeries.DataPoints.Add(dataPoint);
            }

            // 添加數據線到數據序列。                
            chart.Series.Add(dataSeries);

            //將生產的圖表增加到Grid,然後通過Grid添加到上層Grid.           
            Grid gr = new Grid();
            gr.Children.Add(chart);
            Simon.Children.Add(gr);
        }

複製代碼

  折線圖:

複製代碼

public void CreateChartSpline(string name, List<DateTime> lsTime, List<string> cherry, List<string> pineapple)
        {
            //創建一個圖標
            Chart chart = new Chart();

            //設置圖標的寬度和高度
            chart.Width = 580;
            chart.Height = 380;
            chart.Margin = new Thickness(100, 5, 10, 5);
            //是否啓用打印和保持圖片
            chart.ToolBarEnabled = false;

            //設置圖標的屬性
            chart.ScrollingEnabled = false;//是否啓用或禁用滾動
            chart.View3D = true;//3D效果顯示

            //創建一個標題的對象
            Title title = new Title();

            //設置標題的名稱
            title.Text = name;
            title.Padding = new Thickness(0, 10, 5, 0);

            //向圖標添加標題
            chart.Titles.Add(title);

            //初始化一個新的Axis
            Axis xaxis = new Axis();
            //設置Axis的屬性
            //圖表的X軸座標按什麼來分類,如時分秒
            xaxis.IntervalType = IntervalTypes.Months;
            //圖表的X軸座標間隔如2,3,20等,單位爲xAxis.IntervalType設置的時分秒。
            xaxis.Interval = 1;
            //設置X軸的時間顯示格式爲7-10 11:20           
            xaxis.ValueFormatString = "MM月";
            //給圖標添加Axis            
            chart.AxesX.Add(xaxis);

            Axis yAxis = new Axis();
            //設置圖標中Y軸的最小值永遠爲0           
            yAxis.AxisMinimum = 0;
            //設置圖表中Y軸的後綴          
            yAxis.Suffix = "斤";
            chart.AxesY.Add(yAxis);


            // 創建一個新的數據線。               
            DataSeries dataSeries = new DataSeries();
            // 設置數據線的格式。               
            dataSeries.LegendText = "櫻桃";

            dataSeries.RenderAs = RenderAs.Spline;//折線圖

            dataSeries.XValueType = ChartValueTypes.DateTime;
            // 設置數據點              
            DataPoint dataPoint;
            for (int i = 0; i < lsTime.Count; i++)
            {
                // 創建一個數據點的實例。                   
                dataPoint = new DataPoint();
                // 設置X軸點                    
                dataPoint.XValue = lsTime[i];
                //設置Y軸點                   
                dataPoint.YValue = double.Parse(cherry[i]);
                dataPoint.MarkerSize = 8;
                //dataPoint.Tag = tableName.Split('(')[0];
                //設置數據點顏色                  
                // dataPoint.Color = new SolidColorBrush(Colors.LightGray);                   
                dataPoint.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);
                //添加數據點                   
                dataSeries.DataPoints.Add(dataPoint);
            }

            // 添加數據線到數據序列。                
            chart.Series.Add(dataSeries);


            // 創建一個新的數據線。               
            DataSeries dataSeriesPineapple = new DataSeries();
            // 設置數據線的格式。         

            dataSeriesPineapple.LegendText = "菠蘿";

            dataSeriesPineapple.RenderAs = RenderAs.Spline;//折線圖

            dataSeriesPineapple.XValueType = ChartValueTypes.DateTime;
            // 設置數據點              

            DataPoint dataPoint2;
            for (int i = 0; i < lsTime.Count; i++)
            {
                // 創建一個數據點的實例。                   
                dataPoint2 = new DataPoint();
                // 設置X軸點                    
                dataPoint2.XValue = lsTime[i];
                //設置Y軸點                   
                dataPoint2.YValue = double.Parse(pineapple[i]);
                dataPoint2.MarkerSize = 8;
                //dataPoint2.Tag = tableName.Split('(')[0];
                //設置數據點顏色                  
                // dataPoint.Color = new SolidColorBrush(Colors.LightGray);                   
                dataPoint2.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);
                //添加數據點                   
                dataSeriesPineapple.DataPoints.Add(dataPoint2);
            }
            // 添加數據線到數據序列。                
            chart.Series.Add(dataSeriesPineapple);

            //將生產的圖表增加到Grid,然後通過Grid添加到上層Grid.           
            Grid gr = new Grid();
            gr.Children.Add(chart);
            
            Simon.Children.Add(gr);
        }

 

可能用WPF生成過圖表的開發人員都知道,WPF雖然本身的繪圖能力強大,但如果每種圖表都自己去實現一次的話可能工作量就大了,

尤其是在開發時間比較緊的情況下。這時候有必要藉助一種專業的圖表工具。

      Visifire 是專爲WPF、SliverLight、WP開發人員制定的一套圖表控件,實現了一系列的專業圖表(如:柱圖、點圖、雷達、餅圖、K線圖、以及其組合圖等)。

它在4.5版本前都是實驗階段,而且是免費的....所以贏得了大部開發人員的青睞。

      然而在2011年後該公司推出的所有版本都開始收費了,這令許多開發人員忘而卻步...我也是其中之一。

      如果想繼續使用免費版本,那麼就不得不對其下的兩個Dll進行反編譯...就像其它一般的破解方法一樣或者利用WPF的獨特性對其進行控制。

      方法一.反編譯,找到水印的輸出入口,並屏蔽它:

                步驟A: 利用Reflector、Reflexil等工具找到裝載水印的對象[WPFVisifire.Charts,]->[VisifireControl-> CreateWmElement->]

                           this._wMElement.Text = text;//將屏蔽

                步驟B: 利用Reflector、Reflexil等工具找到裝載水印的對象[WPFVisifire.Gauges,]->[VisifireControl-> CreateWmElement->]

                           this._wMElement.Text = text;//將屏蔽

                步驟C: 再利用Reflexil重新編譯。

      方法二.代碼控制:

               找到水印的輸出對象wMElement,將其Visibity設置爲Collapsed

                 this._waterBlock = GetChildObject<TextBlock>(this, "Watermark");
                 if (this._waterBlock.Tag.ToString() == "Watermark")
                {
                    this._waterBlock.Text = string.Empty;
                    this._waterBlock.Visibility = System.Windows.Visibility.Collapsed;
                }

      方法三.樣式控制:

               由於出現的水印叫Visifire Trial Edition,所以可以將系統中出現的所有該字符對象隱藏

              <Application.Resources>
             <Style TargetType="TextBlock">
             <Setter Property="Visibility" Value="Visible" />
              <Style.Triggers>
                <Trigger Property="Text" Value="Visifire Trial Edition">
                    <Trigger.Setters>
                        <Setter Property="Visibility"  Value="Collapsed"></Setter>
                    </Trigger.Setters>
                </Trigger>
              </Style.Triggers>
            </Style>
           </Application.Resources>

  我去掉水印的辦法是在窗體的資源中把水印隱藏,如下圖:這個能去掉水印,但不能去掉“You are using the trial version”

最終去掉水印及“You are using the trial version”的方法是,新寫一個類,繼承Chart然後重寫控件:如下圖,創建統計圖的時候用:  Chart chart = new ChartEx();

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章