c#依參數自動生成控制項

来源:https://www.cnblogs.com/atomy/archive/2018/08/17/9491424.html
-Advertisement-
Play Games

很多系統都帶有自定義報表的功能,而此功能都需依參數自動生成控制項,舉例如下: 如上圖,一條查詢語句當中,包含了3個參數,其中兩個是日期型(使用:DATE!進行標識),一個是字元型(使用:進行標識),要生成的效果圖如下所示: 代碼如下: 好了,分享就到這裡,希望對大家有一些幫助。 ...


  很多系統都帶有自定義報表的功能,而此功能都需依參數自動生成控制項,舉例如下:

  

  如上圖,一條查詢語句當中,包含了3個參數,其中兩個是日期型(使用:DATE!進行標識),一個是字元型(使用:進行標識),要生成的效果圖如下所示:

  

  代碼如下:

private void FrmDefine_MyEventClose(string strID, string strName, string strSql)
{
    //值傳遞
    ReturnID = strID;
    ReturnName = strName;
    ReturnSql = strSql;
    //空格清除
    while (ReturnSql.IndexOf(": ") != -1)
    {
        ReturnSql = ReturnSql.Replace(": ", ":");
    }
    while (ReturnSql.IndexOf(":DATE! ") != -1)
    {
        ReturnSql = ReturnSql.Replace(":DATE! ", ":DATE!");
    }
    //產生標題
    rtxtName.Text = "[" + strID + "]" + strName;
    rtxtName.SelectionAlignment = System.Windows.Forms.HorizontalAlignment.Center;
    //清除控制項
    splitContainer2.Panel1.Controls.Clear();
    //添加控制項
    if (strSql.IndexOf(":") != -1)
    {
        int ParamIndex = 100;   //參數序號,從100往前倒數。
        ParamSql = string.Empty;
        List<string> list = new List<string>(ReturnSql.Split(' '));
        for (int i = list.Count - 1; i > -1; i--)
        {
            if (list[i].IndexOf(":") == -1)
            {
                ParamSql = list[i] + " " + ParamSql;
                list.RemoveAt(i);
            }
            else
            {
                if (list[i].IndexOf(":DATE!") != -1)
                {
                    if (list[i].IndexOf(":DATE!") == 0)
                    {
                        ParamSql = "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                    else
                    {
                        ParamSql = list[i].Substring(0, list[i].IndexOf(":DATE!")) + "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                }
                else
                {
                    if (list[i].IndexOf(":") == 0)
                    {
                        ParamSql = "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                    else
                    {
                        ParamSql = list[i].Substring(0, list[i].IndexOf(":")) + "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                }
            }
        }
        //添加控制項
        if (list.Count > 0)
        {
            //坐標初始化
            Point point = new Point(6, 6);
            //控制項行數
            int intRow = 0;
            //以6個參數為一行,初始化控制項面板的高度。
            splitContainer2.SplitterDistance = 25 * Convert.ToInt32(Math.Ceiling(list.Count / 6.0));
            //控制項添加
            ParamIndex = 100 - list.Count + 1;
            for (int i = 0; i < list.Count; i++)
            {
                string strLabelText = string.Empty;
                if (i % 6 == 0 && i != 0)
                {
                    intRow++;
                    point.X = 6;
                    point.Y = 6 + 25 * intRow;
                }
                //日期及文本
                if (list[i].IndexOf(":DATE!") != -1)
                {
                    //Label
                    strLabelText = list[i].Substring(list[i].IndexOf(":DATE!") + 6, list[i].Length - list[i].IndexOf(":DATE!") - 6);
                    Label label = new Label();
                    label.Name = "Label" + i.ToString();
                    label.Text = strLabelText;
                    label.AutoSize = true;
                    label.Location = point;
                    splitContainer2.Panel1.Controls.Add(label);
                    //DateTimePicker
                    DateTimePicker dateTimePicker = new DateTimePicker();
                    dateTimePicker.Name = "Params[" + ParamIndex.ToString() + "]";
                    dateTimePicker.Format = DateTimePickerFormat.Custom;
                    dateTimePicker.CustomFormat = "yyyy-MM-dd";
                    dateTimePicker.Width = 100;
                    point.X = point.X + label.Width + 4;
                    point.Y = label.Location.Y - 4;
                    dateTimePicker.Location = point;
                    splitContainer2.Panel1.Controls.Add(dateTimePicker);
                    //坐標初始化
                    point.X += 112;
                    point.Y = label.Location.Y;
                }
                else
                {
                    //Label
                    strLabelText = list[i].Substring(list[i].IndexOf(":") + 1, list[i].Length - list[i].IndexOf(":") - 1);
                    Label label = new Label();
                    label.Name = "Label" + i.ToString();
                    label.Text = strLabelText;
                    label.AutoSize = true;
                    label.Location = point;
                    splitContainer2.Panel1.Controls.Add(label);
                    //TextBox
                    TextBox textBox = new TextBox();
                    textBox.Name = "Params[" + ParamIndex.ToString() + "]";
                    textBox.Text = string.Empty;
                    textBox.Width = 100;
                    point.X = point.X + label.Width + 4;
                    point.Y = label.Location.Y - 4;
                    textBox.Location = point;
                    splitContainer2.Panel1.Controls.Add(textBox);
                    //坐標初始化
                    point.X += 112;
                    point.Y = label.Location.Y;
                }
                //參數序號賦值
                ParamIndex++;
            }
        }
    }
    //數據源初始化
    dataGridView1.DataSource = null;
}

  好了,分享就到這裡,希望對大家有一些幫助。


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

-Advertisement-
Play Games
更多相關文章
  • 問題:考慮屏幕大小,一般都是會在表單問卷的頁面使用ScrollViewer。問卷中問題漏填漏選時,在提交時校驗不過,需要滾動跳轉至漏填漏選項。 頁面如下: 每個選項使用StackPanel,並對覆選框和單選的勾選事件進行答案記錄,使用全局變數記錄 將所有選項使用StackPanel指定垂直樣式,思路 ...
  • 索引 NET Core應用框架之BitAdminCore框架應用篇系列 框架演示:https://www.bitadmincore.com 框架源碼:https://github.com/chenyinxin/cookiecutter-bitadmin-core 什麼是.NET Core Globa ...
  • 最近我跟一個漏洞還有一群阿三幹起來了…… 背景: 我的客戶是一個世界知名的藥企,最近這個客戶上臺了一位阿三管理者,這個貨上線第一個事兒就是要把現有的軟體供應商重新洗牌一遍。由於我們的客戶關係維護的非常好,直接對口人提前透露給我們這個管理者就是想讓一個阿三公司壟斷他們的軟體供應,並且表示了非常鄙視。我 ...
  • 索引 NET Core應用框架之BitAdminCore框架應用篇系列 框架演示:http://bit.bitdao.cn 框架源碼:https://github.com/chenyinxin/cookiecutter-bitadmin-core 20180817更新內容 1、考慮到大部分項目不需要 ...
  • 本節對委托、事件做以總結。 一、委托: 1、概念:先來說明變數和函數的概念,變數,以某個地址為起點的一段記憶體中所存儲的值,函數,以某個地址為起點的一段記憶體中存儲的機器語言指令。有了這2個概念以後,我們來看c++中的函數指針,函數指針就是指向這個函數的地址,函數指針所指向的類型就是函數在記憶體中的大小, ...
  • 通過以下步驟,可以簡單瞭解到如何下載我們Smobiler Designer(設計器)、Client(客戶端),以及如何通過設計器進行開發和調試移動應用,併在服務端部署、Cloud打包、訪問自己所開發的移動應用。 ...
  • 對谷歌瓦片地圖進行糾偏,有兩種方法:一是對拼接大圖進行糾偏,然後重新切片;二是直接對瓦片圖進行糾偏。這裡我用的是第二種方法,即直接對瓦片地圖進行糾偏。 App.config配置: <appSettings> <add key="inputPath" value="D:\_臨時文件\GISMap\18 ...
  • 簡介 ASP.NET Boilerplate提供了構建模塊的基礎結構,並將它們組合在一起以創建應用程式。 模塊可以依賴於另一個模塊。 通常,一個程式集被視為一個模塊。 如果創建具有多個程式集的應用程式,建議您為每個程式集創建一個模塊定義。 模塊系統目前專註於服務端,而不是客戶端。 模塊定義 定義一個 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...