Winform中跨窗體設置Zedgraph的屬性並刷新曲線圖

来源:https://www.cnblogs.com/badaoliumangqizhi/archive/2019/09/16/11525826.html
-Advertisement-
Play Games

場景 在使用ZedGraph時,經常有圖形選項功能,設置曲線圖相關屬性後, 點擊保存會設置另一個窗體的屬性並刷新圖。 效果 實現 在設置圖形的選項的類中,聲明委托和事件 在當前窗體的確定按鈕的點擊事件中 將相關曲線圖的Y軸以及X軸的相關屬性存到xml配置文件中,然後調用方法 去刷新曲線圖,使其重新加 ...


場景

在使用ZedGraph時,經常有圖形選項功能,設置曲線圖相關屬性後,

點擊保存會設置另一個窗體的屬性並刷新圖。

效果

 

 

實現

在設置圖形的選項的類中,聲明委托和事件

//委托的定義
public delegate void ReloadPanelDelegete();
//事件聲明
public static event ReloadPanelDelegete reloadPanelEvent;

 

在當前窗體的確定按鈕的點擊事件中

將相關曲線圖的Y軸以及X軸的相關屬性存到xml配置文件中,然後調用方法

去刷新曲線圖,使其重新載入。

private void confirmbButton_Click(object sender, EventArgs e)
        {
            #region 獲取X軸的屬性並賦值給XAxisModel
            //對X軸的屬性配置文件進行保存
            //根據控制項的 System.Windows.Forms.Control.Name 屬性搜索控制項並生成由所有匹配項組成的數組。
            //如果搜索所有子控制項,則為 true;否則為 false。
            XAxisModel xAxisModel = new XAxisModel();
            //獲取標題
            RadioGroup radioGroupX = this.Controls.Find("radioGroupX", true)[0] as RadioGroup;
            xAxisModel.Title = radioGroupX.Text;
            //獲取下限
            TextEdit minTextEditX = this.Controls.Find("minTextEditX", true)[0] as TextEdit;
            xAxisModel.Min = Double.Parse(minTextEditX.Text);
            //獲取上限
            TextEdit maxTextEditX = this.Controls.Find("maxTextEditX", true)[0] as TextEdit;
            xAxisModel.Max = Double.Parse(maxTextEditX.Text);
            //獲取顏色
            ColorEdit colorEditX = this.Controls.Find("colorEditX", true)[0] as ColorEdit;
            xAxisModel.Color = colorEditX.Text;
            #endregion

            #region 將X軸的屬性存到配置文件中
            Boolean isWriteX = ChartOptionHelper.setXAxisAttribute(xAxisModel);
            #endregion

            #region 獲取Y軸屬性並賦值給List<YAxisModel>
            List<YAxisModel> yAxisModelList = new List<YAxisModel>();
            for (int i = 1; i <= yAxisCount; i++)
            {
                YAxisModel yAxisModel = new YAxisModel();
                //獲取標題
                RadioGroup radioGroupY = this.Controls.Find("radioGroupY" + i, true)[0] as RadioGroup;
                yAxisModel.Title = radioGroupY.Text;
                //獲取下限
                TextEdit minTextEditY = this.Controls.Find("minTextEditY" + i, true)[0] as TextEdit;
                yAxisModel.Min = Double.Parse(minTextEditY.Text);
                //獲取上限
                TextEdit maxTextEditY = this.Controls.Find("maxTextEditY" + i, true)[0] as TextEdit;
                yAxisModel.Max = Double.Parse(maxTextEditY.Text);
                //獲取顏色
                ColorEdit colorEditY = this.Controls.Find("colorEditY" + i, true)[0] as ColorEdit;
                yAxisModel.Color = colorEditY.Text;
                yAxisModelList.Add(yAxisModel);
            }
            #endregion

            #region 將Y軸的屬性存到配置文件中
            Boolean isWriteY = ChartOptionHelper.setYAxisAttribute(yAxisModelList);
            #endregion

            #region 彈出對話框並設置點擊確定之後的事件
            if (isWriteX == true && isWriteY == true)
            {
                if (this.Confirm("保存成功") == DialogResult.OK)
                {
                    //將是否第一次打開軟體的標識量改為0,,下次打開直接讀取配置文件
                    Global.isFirstOpen = 0;
                    if (reloadPanelEvent != null)
                    {
                        reloadPanelEvent();
                    }
                    this.Dispose();
                }
            }
            else
            {
                DevExpress.XtraEditors.XtraMessageBox.Show("保存失敗", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
            }
            #endregion

        }

 

然後在曲線圖顯示的窗體中訂閱事件

Dialog.ChartOption.reloadPanelEvent += new Dialog.ChartOption.ReloadPanelDelegete(reloadPanel);

其中左邊的類是上面圖形選項的類,右邊的類是窗體顯示的類

然後在窗體顯示的類中新建圖上面ReloadPanelDelegete的參數同名的方法reloadPanel實現曲線圖的刷新。

public void reloadPanel()
        {
            //聲明pane對象
            GraphPane myPane = new GraphPane();
            //獲取控制項的Pane
            myPane = this.zedGraphControl1.GraphPane;
            #region 從配置文件中載入並設置X軸屬性
            //獲取X軸屬性
            XAxisModel xAttribute = ChartOptionHelper.getXAxisAttribute(Global.RADIO_GROUP_YAXIS_FILEPATH_X);
            myPane.XAxis.Title.Text = xAttribute.Title;
            myPane.XAxis.Color = System.Drawing.ColorTranslator.FromHtml(xAttribute.Color);
            myPane.XAxis.Scale.Min = xAttribute.Min;
            myPane.XAxis.Scale.Max = xAttribute.Max;
            #endregion
           
            //獲取配置文件載入的Y軸的list
            List<YAxisModel> yLoadList = ChartOptionHelper.getYAxisList(Global.RADIO_GROUP_YAXIS_FILEPATH);
            //用來存儲標題不為空的list
            List<YAxisModel> yList = new List<YAxisModel>();
            foreach (YAxisModel yAxisModel in yLoadList)
            {
                if (!yAxisModel.Title.Equals(""))
                {
                    yList.Add(yAxisModel);
                }
            }
            //根據數量生成Y軸
            //說明選擇全是空標題
            if (yList.Count == 0)
            {
                //設置X軸標題
                myPane.XAxis.Title.Text = "時間";
                //X軸線的顏色
                myPane.XAxis.Color = Color.Black;
                //設置第一條Y軸標題
                myPane.YAxis.Title.Text = "Y1";
                this.zedGraphControl1.Invalidate();
            }
            else if (yList.Count == 1)
            {
                //設置第一條Y軸標題
                myPane.YAxis.Title.Text = yList[0].Title;
                myPane.YAxis.Scale.Min = yList[0].Min;
                myPane.YAxis.Scale.Max = yList[0].Max;
                myPane.YAxis.Color = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                myPane.Y2Axis.Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                myPane.YAxis.Scale.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                this.zedGraphControl1.Invalidate();
            }
            else if (yList.Count == 2)
            {
                //設置第一條Y軸標題
                myPane.YAxis.Title.Text = yList[0].Title;
                myPane.YAxis.Scale.Min = yList[0].Min;
                myPane.YAxis.Scale.Max = yList[0].Max;
                myPane.YAxis.Color = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                myPane.YAxis.Color = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                myPane.Y2Axis.Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                //第二條Y軸標題
                myPane.Y2Axis.Title.Text = yList[1].Title;
                //第二條Y軸下限
                myPane.Y2Axis.Scale.Min = yList[1].Min;
                //第二條Y軸上限
                myPane.Y2Axis.Scale.Max = yList[1].Max;
                //設置顏色 
                myPane.Y2Axis.Color = System.Drawing.ColorTranslator.FromHtml(yList[1].Color);
                //設置刻度線字體顏色
                myPane.Y2Axis.Scale.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[1].Color);
                //設置標題字體顏色
                myPane.Y2Axis.Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[1].Color);
                //標題大小
                myPane.Y2Axis.Title.FontSpec.Size = Global.FONT_SIZE;
                myPane.Y2Axis.Title.FontSpec.Family = Global.FONT_FAMILY;
                myPane.Y2Axis.Title.FontSpec.IsBold = false;
                //顯示小刻度 是false則看不到效果
                myPane.Y2Axis.MinorGrid.IsVisible = true;
                //設置Y軸刻度線字體大小
                myPane.Y2Axis.Scale.FontSpec.Size = Global.FONT_SIZE;
                //讓第二條Y軸顯示
                myPane.Y2Axis.IsVisible = true;
                this.zedGraphControl1.Invalidate();
            }
            //否則就是新增第三條及以上
            else
            {
                //設置第一條Y軸標題
                myPane.YAxis.Title.Text = yList[0].Title;
                myPane.YAxis.Scale.Min = yList[0].Min;
                myPane.YAxis.Scale.Max = yList[0].Max;
                myPane.YAxis.Scale.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                myPane.YAxis.Color = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                //第二條Y軸標題
                myPane.Y2Axis.Title.Text = yList[1].Title;
                myPane.Y2Axis.Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[0].Color);
                //第二條Y軸下限
                myPane.Y2Axis.Scale.Min = yList[1].Min;
                //第二條Y軸上限
                myPane.Y2Axis.Scale.Max = yList[1].Max;
                //設置顏色 
                myPane.Y2Axis.Color = System.Drawing.ColorTranslator.FromHtml(yList[1].Color);
                //設置刻度線字體顏色
                myPane.Y2Axis.Scale.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[1].Color);
                //設置標題字體顏色
                myPane.Y2Axis.Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[1].Color);
                //標題大小
                myPane.Y2Axis.Title.FontSpec.Size = Global.FONT_SIZE;
                myPane.Y2Axis.Title.FontSpec.Family = Global.FONT_FAMILY;
                myPane.Y2Axis.Title.FontSpec.IsBold = false;
                //顯示小刻度 是false則看不到效果
                myPane.Y2Axis.MinorGrid.IsVisible = true;
                //設置Y軸刻度線字體大小
                myPane.Y2Axis.Scale.FontSpec.Size = Global.FONT_SIZE;
                //讓第二條Y軸顯示
                myPane.Y2Axis.IsVisible = true;
                #region 第一次載入其他的Y軸,要在Y軸的List中add進Y軸
                //說明是第一次載入其他的Y軸,要在Y軸的List中add進Y軸
                if (myPane.YAxisList.Count == 1)
                {
                    //迴圈剩下的Y軸並顯示
                    for (int i = 2; i < yList.Count; i++)
                    {
                        YAxis yAxisNew = new YAxis(yList[i].Title);
                        yAxisNew.Scale.Min = yList[i].Min;
                        yAxisNew.Scale.Max = yList[i].Max;
                        //設置Y軸顏色
                        yAxisNew.Color = System.Drawing.ColorTranslator.FromHtml(yList[i].Color);
                        //設置刻度線字體顏色
                        yAxisNew.Scale.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[i].Color);
                        //設置標題字體顏色
                        yAxisNew.Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[i].Color);
                        yAxisNew.Type = AxisType.Text;
                        //顯示小刻度 是false則看不到效果
                        yAxisNew.MinorGrid.IsVisible = true;
                        //關閉相反的tics,使y2 tics不會顯示在y軸上
                        yAxisNew.MajorTic.IsInside = true;
                        yAxisNew.MinorTic.IsInside = true;
                        yAxisNew.MajorTic.IsOpposite = true;
                        yAxisNew.MinorTic.IsOpposite = true;
                        yAxisNew.Title.FontSpec.Family = Global.FONT_FAMILY;
                        yAxisNew.Title.FontSpec.Size = Global.FONT_SIZE;
                        yAxisNew.Title.FontSpec.IsBold = false;
                        //設置Y軸刻度線字體大小
                        yAxisNew.Scale.FontSpec.Size = Global.FONT_SIZE;
                        //添加到Y軸的list
                        myPane.YAxisList.Add(yAxisNew);
                    }
                }
                #endregion
                else
                {
                    //迴圈剩下的Y軸並顯示
                    for (int i = 1; i < myPane.YAxisList.Count; i++)
                    {
                        myPane.YAxisList[i].Scale.Min = yList[i+1].Min;
                        myPane.YAxisList[i].Scale.Max = yList[i + 1].Max;
                        //設置Y軸顏色
                        myPane.YAxisList[i].Color = System.Drawing.ColorTranslator.FromHtml(yList[i+1].Color);
                        //設置刻度線字體顏色
                        myPane.YAxisList[i].Scale.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[i + 1].Color);
                        //設置標題字體顏色
                        myPane.YAxisList[i].Title.FontSpec.FontColor = System.Drawing.ColorTranslator.FromHtml(yList[i + 1].Color);
                        myPane.YAxisList[i].Type = AxisType.Text;
                        //顯示小刻度 是false則看不到效果
                        myPane.YAxisList[i].MinorGrid.IsVisible = true;
                        //關閉相反的tics,使y2 tics不會顯示在y軸上
                        myPane.YAxisList[i].MajorTic.IsInside = true;
                        myPane.YAxisList[i].MinorTic.IsInside = true;
                        myPane.YAxisList[i].MajorTic.IsOpposite = true;
                        myPane.YAxisList[i].MinorTic.IsOpposite = true;
                        myPane.YAxisList[i].Title.FontSpec.Family = Global.FONT_FAMILY;
                        myPane.YAxisList[i].Title.FontSpec.Size = Global.FONT_SIZE;
                        myPane.YAxisList[i].Title.FontSpec.IsBold = false;
                        //設置Y軸刻度線字體大小
                        myPane.YAxisList[i].Scale.FontSpec.Size = Global.FONT_SIZE;
                        
                    }
                }
                this.zedGraphControl1.Invalidate();
            }
        }

 

註:

1.mypane是ZedGraph的面板,其預設是有一條Y軸對象的,為myPane.YAxis

2.如果要顯示第二條Y軸,ZedGraph是預設存在第二條Y軸的,為myPane.Y2Axis,不過就是預設不顯示,要使其顯示,需要myPane.Y2Axis.IsVisible = true;

3.如果是三條以上Y軸的話,就要使用

myPane.YAxisList.Add(yAxisNew);

 

加入其Y軸的list。

4.這裡的需求是首次打開預設載入一條Y軸,所以在首次載入時判斷

myPane.YAxisList.Count == 1,其自己的List是否為1,為1則代表是首次載入,下次再設置並載入時,其list就不為1了。所以需要是設置,而不是再往list中新增了。

5.需要註意的是,如果顯示4條Y軸的話,其myPane.YAxisList.Count為3,,一條是不算在內的。

6.刷新曲線圖的代碼

this.zedGraphControl1.Invalidate();

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在用asp.net identity的時候,發現很多概念不是很懂,特地去查資料瞭解了一些相關信息,現在做下筆記。 1、OWIN,OWIN是Open Web Server Interface for .NET的首字母縮寫,他的定義如下: OWIN在.NET Web Servers與Web Applic ...
  • 場景 FastReport .NET 2019是一款適用於Windows Forms, ASP.NET和MVC框架的功能齊全的報表分析解決方案。可用在Microsoft Visual Studio 2005到2015,支持.Net Framework 2.0到4.x,.Net Core 2.0。同時 ...
  • DateTime Monday = Convert.ToDateTime(DateTime.Now.AddDays(1 - Convert.ToInt32(DateTime.Now.DayOfWeek)).ToString("D").ToString()); DateTime Sunday = Mo ...
  • 使用多表查詢進行關聯時,提示 join子句中其中一個表達式的類型不正確,註意欄位類型和名稱要一致,否則join時提示語法錯誤,錯誤截圖如下 ...
  • 場景 DevExpress的RadioGroup的items選項如果是不確定的話,需要其從配置文件中載入。 實現 在項目目錄下新建Config文件夾,文件夾下新建xml配置文件。 並且設置在其較新時複製到輸出目錄: 然後在顯示RadioGroup的窗體的載入事件中。 讀取配置文件中的item選項。 ...
  • 之前的ResourceDictionary主題資源替換(一)通過載入順序來覆蓋之前的主題資源,介紹了WPF框架對ResourceDictionary資源的合併規則。 此篇介紹一種在編譯期間,實現資源替換的方案 前言 如下圖,項目中存在倆個主題資源字典,我們想通過配置一鍵修改項目的主題。 首先,我們默 ...
  • 前言:第一次寫文章,有問題請輕噴 當前使用 Net Core 版本 2.1.3 我們經常在開發中需要把實體的主鍵 Id 傳輸到前端,但是在Get的時候又不想讓前端能看到明文,我們通常會加密這些數據,所以有了這篇文章來寫一些心得。(主要是我在網上找的代碼寫得太簡單了,不符合我的需求) 這裡我用的是 N ...
  • 場景 有時需要使用配置文件保存一些配置的屬性,使其在下次打開時設置仍然生效。 這裡以對xml配置文件的讀寫為例。 1.讀取XML配置文。 2.寫入XML配置文件。 3.匹配 XPath 表達式的第一個 XmlNode。 4.獲取節點text。 5.根據xPath獲取節點個數。 6.根據xPath獲取 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...