Code Monkey home page Code Monkey logo

kwwwvagaa / netwinformcontrol Goto Github PK

View Code? Open in Web Editor NEW
2.2K 111.0 627.0 14.74 MB

HZHControls,c#winfrom custom control, has better operation support for touch screen, the project is based on framework4.0, completely native control development, do not use any third-party controls, you can use it safely in your project (winfromcontrol/winformcontrol/.net).There are more abundant industrial controls that continue to increase in the ~~~

License: Mozilla Public License 2.0

C# 100.00% Batchfile 0.01%

netwinformcontrol's Introduction

Website

NetWinformCustom Controls

My english is poor. The English below is from Google Translate. Please forgive me.

Introduction

c#winform custom control, has better operation support for touch screen, the project is based on framework4.0, completely native control development, do not use any third-party controls, you can use it safely in your project .

Blog address: https://www.cnblogs.com/bfyx

GitHub: https://github.com/kwwwvagaa/NetWinformControl

Code Cloud: https://gitee.com/kwwwvagaa/net_winform_custom_control.git

Welcome to exchange discussion: Click to join QQ group 568015492

If my code is useful to you, please reward me, thank you, your reward is my motivation.

输入图片说明 输入图片说明

The source code is only for exchange learning. The open source agreement is MPL 2.0. For commercial use, please contact the group owner.

Come here, come to a Star and let's go.

NuGet

Install-Package HZH_Controls
The content listed below is only part of the control, more control effects, please download the source code to see the demo running effect!

输入图片说明 输入图片说明

Sample

1, prompt window renderings

sample image sample image

If (FrmDialog.ShowDialog(this, "Do you want to display a prompt box without a cancel button?", "Mode Form Test", true) == System.Windows.Forms.DialogResult.OK)
{
    FrmDialog.ShowDialog(this, "This is a prompt box without a cancel button", "Mode Form Test");
}
2, multiple input form

sample image

 FrmInputs frm = new FrmInputs("Dynamic Multi-Input Form Test",
                New string[] { "name", "telephone", "ID number", "address" },
                New Dictionary<string, HZH_Controls.TextInputType>() { { "Phone", HZH_Controls.TextInputType.Regex }, { "ID number", HZH_Controls.TextInputType.Regex } },
                New Dictionary<string, string>() { { "phone", "^1\\d{10}$" }, { "ID number", "^\\d{18}$" } },
                New Dictionary<string, KeyBoardType>() { { "phone", KeyBoardType.UCKeyBorderNum }, { "ID number", KeyBoardType.UCKeyBorderNum } },
                New List<string>() { "name", "telephone", "identity number" });
frm.ShowDialog(this);
/// <summary>
/// Function Description: Constructor
/// Author: HZH
/// Creation date: 2019-08-05 10:57:26
/// Task number: POS
/// </summary>
/// <param name="strTitle">form title</param>
/// <param name="args">Input name</param>
/// <param name="inTypes">Input type corresponds to input type, key: input item name, if no default control input is not set </param>
/// <param name="regexs">The input item corresponds to the regular rule, valid when imTypes=Regex, key: input item name, if you do not set the default no control input </param>
/// <param name="keyBoards"> text box keyboard, key: input item name, if you do not set the default English keyboard </param>
/// <param name="mastInputs">Required entry name</param>
/// <param name="defaultValues">Input default value, key: input name </param>
Public FrmInputs(
    String strTitle,
    String[] inPutLabels,
    Dictionary<string, TextInputType> inTypes = null,
    Dictionary<string, string> regexs = null,
    Dictionary<string, HZH_Controls.Controls.KeyBoardType> keyBoards = null,
    List<string> mastInputs = null,
    Dictionary<string, string> defaultValues ​​= null)
3, Temp1 form

sample image

/ / New form FrmTemp1Test inherits HZH_Controls.Forms.FrmTemp1
FrmTemp1Test frm = new FrmTemp1Test();
frm.ShowDialog(this);
4, there is a form to confirm cancellation 1

sample image

/ / New form FrmOKCancel1Test inherits HZH_Controls.Forms.FrmWithOKCancel1
FrmOKCancel1Test frm = new FrmOKCancel1Test();
frm.ShowDialog(this);
5, there is a form to confirm cancellation 2

sample image

/ / New form FrmOKCancel2Test inherits HZH_Controls.Forms.FrmWithOKCancel2
FrmOKCancel2Test frm = new FrmOKCancel2Test();
frm.ShowDialog(this);
6, single title form

sample image

/ / New form FrmWithTitleTest inherits HZH_Controls.Forms.FrmWithTitle
FrmWithTitleTest frm = new FrmWithTitleTest();
frm.ShowDialog(this);
7, control

输入图片说明

Text box keyboard effect

sample image sample image sample image

`Handwriting input requires the handwriting support of Sogou, please copy the HandInput folder to the running directory.

Time control effect

sample image sample image sample image

  • Drop-down list data binding *
/ / Use the method is similar to the native ComboBox
List<KeyValuePair<string, string>> lstCom = new List<KeyValuePair<string, string>>();
For (int i = 0; i < 5; i++)
{
    lstCom.Add(new KeyValuePair<string, string>(i.ToString(), "options" + i));
}

this.ucComboBox1.Source = lstCom;
this.ucComboBox2.Source = lstCom;
this.ucComboBox1.SelectedIndex = 1;
this.ucComboBox2.SelectedIndex = 1;

Tree data binding

/ / Use the same method as the native Treeview, set the property IsShowByCustomModel = true to enable the custom mode, otherwise the original tree
For (int i = 0; i < 5; i++)
{
    TreeNode tn = new TreeNode("parent node" + i);
    For (int j = 0; j < 5; j++)
    {
        tn.Nodes.Add("child node" + j);
    }
    this.treeViewEx1.Nodes.Add(tn);
}

List data binding

/ / Customizable color fonts, etc.
List<ListEntity> lst = new List<ListEntity>();
For (int i = 0; i < 5; i++)
{
    lst.Add(new ListEntity()
    {
        ID = i.ToString(),
        Title = "options" + i,
        ShowMoreBtn = true,
        Source = i
    });
}
this.ucListExt1.SetList(lst);
  • Horizontal list data binding*
List<KeyValuePair<string, string>> lstHL = new List<KeyValuePair<string, string>>();
For (int i = 0; i < 30; i++)
{
    lstHL.Add(new KeyValuePair<string, string>(i.ToString(), "options" + i));
}

this.ucHorizontalList1.DataSource = lstHL;
8, Datagridview

sample image

List<DataGridViewColumnEntity> lstCulumns = new List<DataGridViewColumnEntity>();
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "Number", Width = 70, WidthType = SizeType.Absolute });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "Name", Width = 50, WidthType = SizeType.Percent });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "Age", Width = 50, WidthType = SizeType.Percent });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "Birthday", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((DateTime)a).ToString(" yyyy-MM-dd"); } });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "Gender", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((int)a) == 0 ? "female": "male"; } });
this.ucDataGridView1.Columns = lstCulumns;
this.ucDataGridView1.IsShowCheckBox = true;
List<object> lstSource = new List<object>();
For (int i = 0; i < 20; i++)
{
    TestModel model = new TestModel()
    {
        ID = i.ToString(),
        Age = 3 * i,
        Name = "name -" + i,
        Birthday = DateTime.Now.AddYears(-10),
        Sex = i % 2
    };
    lstSource.Add(model);
}

this.ucDataGridView1.DataSource = lstSource;
this.ucDataGridView1.First();

When using the paging control, you no longer need to specify the DataSource data source property, just specify the DataSource property of the page turning control

If the preset table row does not meet your needs, you can also customize the row control by:

  1. Add a custom control to implement the interface IDataGridViewRow
  2. Implement your custom line with UCDataGridViewRow
  3. Set the RowType property of the datagridview.

Page property defines the page turning control. If UCPagerControl does not meet your needs, please customize the page turning control and inherit UCPagerControlBase. When the page flip control is not enabled when it is empty, the appropriate data will be displayed on each page when the page flip control is enabled, and the scroll bar no longer appears.

9, page turning control

sample image

Another paging control style

sample image

List<DataGridViewColumnEntity> lstCulumns = new List<DataGridViewColumnEntity>();
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "Number", Width = 70, WidthType = SizeType.Absolute });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "Name", Width = 50, WidthType = SizeType.Percent });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "Age", Width = 50, WidthType = SizeType.Percent });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "Birthday", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((DateTime)a).ToString(" yyyy-MM-dd"); } });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "Gender", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((int)a) == 0 ? "female": "male"; } });
this.ucDataGridView1.Columns = lstCulumns;
this.ucDataGridView1.IsShowCheckBox = true;
List<object> lstSource = new List<object>();
For (int i = 0; i < 20; i++)
{
    TestModel model = new TestModel()
    {
        ID = i.ToString(),
        Age = 3 * i,
        Name = "name -" + i,
        Birthday = DateTime.Now.AddYears(-10),
        Sex = i % 2
    };
    lstSource.Add(model);
}

UCPagerControl page = new UCPagerControl();
//UCPagerControl2 page = new UCPagerControl2();
page.DataSource = lstSource;
this.ucDataGridView1.Page = page;
this.ucDataGridView1.First();

If UCPagerControl does not meet your needs, please customize the page flip control and inherit UCPagerControlBase, such as changing the style, adding logic, etc.

If you need to subscript a page of data starting from 10, you can set StartIndex = 10, then call GetCurrentSource (), the usage is as follows:

m_page.DataSource=lstSource;
m_page.PageSize = ShowCount;
m_page.StartIndex=10;
this.dgv.DataSource = m_page.GetCurrentSource();

The page flip control can be used for any list-type control. The above code example only uses the datagridview to illustrate usage. The usage is as follows:

  1. Set the property DataSource data source
  2. Set the property PageSize to display the amount of data per page.
  3. Set the time ShowSourceChanged to set the current page data source to the target control in time.
  4. If the first page of data is not displayed after the page is loaded, you can manually call GetCurrentSource() and assign it to the target control, for example:
m_page.DataSource=lstSource;
m_page.PageSize = ShowCount;
this.dgv.DataSource = m_page.GetCurrentSource();
10, bubble tips renderings (5 built-in and custom styles)

sample image

FrmTips.ShowTipsError(this, "Error prompt message");
FrmTips.ShowTipsInfo(this, "Info prompt information");
FrmTips.ShowTipsSuccess(this, "Success prompt information");
FrmTips.ShowTipsWarning(this, "Warning prompt information");
/*Customize can be used
Public static FrmTips ShowTips(
            Form frm,
            String strMsg,
            Int intAutoColseTime = 0,
            Bool blnShowCoseBtn = true,
            ContentAlignment align = ContentAlignment.BottomLeft,
            Point? point = null,
            TipsSizeMode mode = TipsSizeMode.Small,
            Size? size = null,
            TipsState state = TipsState.Default)
*/
11, multi-threaded operation waiting

sample image

/ / This form is generally used in the time-consuming thread operation to display the waiting animation, the following is a multi-threaded time-consuming operation example
ControlHelper.ThreadRunExt(this, () =>
{
    Thread.Sleep(5000);
    ControlHelper.ThreadInvokerControl(this, () =>
    {
        FrmTips.ShowTipsSuccess(this, "FrmWaiting test");
    });
}, null, this);
//ControlHelper.ThreadRunExt to open a thread to perform tasks
//ControlHelper.ThreadInvokerControl is an asynchronous delegate call control
/// <summary>
/// Use one thread to perform an operation
/// </summary>
/// <param name="parent">parent control</param>
/// <param name="func">Execution content</param>
/// <param name="callback">post-execution callback</param>
/// <param name="enableControl">Disable control list during execution</param>
/// <param name="blnShowSplashScreen">Whether waiting for a prompt is displayed during execution</param>
/// <param name="strMsg">When waiting for the prompt during execution, the default is "Processing, please wait..."</param>
/// <param name="intSplashScreenDelayTime">Delayed display waiting reminder time</param>
Public static void ThreadRunExt(
    Control parent,
    Action func,
    Action<object> callback,
    Control[] enableControl = null,
    Bool blnShowSplashScreen = true,
    String strMsg = null,
    Int intSplashScreenDelayTime = 200)
12, menu navigation control

sample image

List<MenuItemEntity> lstMenu = new List<MenuItemEntity>();
For (int i = 0; i < 5; i++)
{
    MenuItemEntity item = new MenuItemEntity()
    {
        Key = "p" + i.ToString(),
        Text = "menu item" + i,
        DataSource = "Have some custom data sources for extension here"
    };
    item.Childrens = new List<MenuItemEntity>();
    For (int j = 0; j < 5; j++)
    {
        MenuItemEntity item2 = new MenuItemEntity()
        {
            Key = "c" + i.ToString(),
            Text = "menu item" + i + "-" + j,
            DataSource = "Have some custom data sources for extension here"
        };
        item.Childrens.Add(item2);
    }
    lstMenu.Add(item);
}
this.ucMenu1.DataSource = lstMenu;

If the preset style does not meet your needs, you can also customize the node control by:

  1. Add a custom control to implement the interface IMenuItem, which can define the parent node and the child node respectively.
  2. Implement your custom node with reference to UCMenuChildrenItem or UCMenuParentItem
  3. Set the parent node ParentItemType property of the UCMenu and the childItemChildItemType property.

If you want to modify the node style, such as the background color, you can use UCMenu's ParentItemStyles or ChildrenItemStyles, such as

this.ucMenu1.ParentItemStyles = new Dictionary<string, object>() { {"BackColor",Color.Red } };
this.ucMenu1.ChildrenItemStyles = new Dictionary<string, object>() { {"BackColor",Color.Yellow } };

The default display style of the menu is Fill. When there are more menu items, the sub-items cannot be displayed. In this case, you should modify the menu style to Top.

this.ucMenu1.MenuStyle = MenuStyle.Top;

 

13, button group

sample image

ucBtnsGroup1.DataSource = new Dictionary<string, string>() { { "1", "male" }, { "0", "female" } };
ucBtnsGroup2.IsMultiple = true;
ucBtnsGroup2.DataSource = new Dictionary<string, string>() { { "1", "Henan" }, { "2", "Beijing" }, { "3", "Hunan" }, { "4", " Shanghai" } };
ucBtnsGroup2.SelectItem = new List<string>() { "2","3"};
14, Tab page

sample image

15, step control

sample image sample image

16, panel with title

sample image

17, progress bar

Progress bar supports ring or fan display, support for percentage and value display

sample image sample image

sample image

sample image

输入图片说明

18, breadcrumb navigation

sample image

19, switch

sample image

20、ListView

sample image sample image

The ListView item element provides an interface implementation. When you feel that the sub-items I wrote don't meet your needs, you can add a control, implement the interface, and then assign your control to the ListItem's property ItemType.

Similarly, I also provide a page turning control, property Page, as long as the page flip control that inherits UCPagerControlBase can be compatible, of course, you can also use the page turning control.

Take a look at the call.

List<object> lstSource = new List<object>();
For (int i = 0; i < 200; i++)
{
     lstSource.Add("item-" + i);
}
/ / Use the paging control
Var page = new UCPagerControl2();
page.DataSource = lstSource;
this.ucListView1.Page = page;
/ / Do not use paging controls
//this.ucListView1.DataSource = lstSource;
21, water wave

sample image

22, waveform chart

sample image

//Timer randomly adds numbers at regular intervals
Random r = new Random();
Int i = r.Next(100, 1000);
this.ucWaveWithSource1.AddSource(i.ToString(), i);
23, TreeGrid

Enter image description

 Private void FrmTemp1Test_Load(object sender, EventArgs e)
        {
            this.ucDataGridView1.RowType = typeof(UCDataGridViewTreeRow);
            this.ucDataGridView1.IsAutoHeight = true;

            List<DataGridViewColumnEntity> lstCulumns = new List<DataGridViewColumnEntity>();
            lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "Number", Width = 70, WidthType = SizeType.Absolute });
            lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "Name", Width = 50, WidthType = SizeType.Percent });
            lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "Age", Width = 50, WidthType = SizeType.Percent });
            lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "Birthday", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((DateTime)a).ToString(" yyyy-MM-dd"); } });
            lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "Gender", Width = 50, WidthType = SizeType.Percent, Format = (a) => { return ((int)a) == 0 ? "female": "male"; } });
            this.ucDataGridView1.Columns = lstCulumns;
            this.ucDataGridView1.IsShowCheckBox = true;
            List<object> lstSource = new List<object>();
            For (int i = 0; i < 200; i++)
            {
                TestModel model = new TestModel()
                {
                    ID = i.ToString(),
                    Age = 3 * i,
                    Name = "name -" + i,
                    Birthday = DateTime.Now.AddYears(-10),
                    Sex = i % 2
                };
                lstSource.Add(model);
                AddChilds(model, 5);
            }

            Var page = new UCPagerControl2();
            page.DataSource = lstSource;
            this.ucDataGridView1.Page = page;
            this.ucDataGridView1.First();
        }

        Private void AddChilds(TestModel tm, int intCount)
        {
            If (intCount <= 0)
                Return;
            tm.Childrens = new List<TestModel>();
            For (int i = 0; i < 5; i++)
            {
                TestModel model = new TestModel()
                {
                    ID = i.ToString(),
                    Age = 3 * i,
                    Name = intCount + "-" + i,
                    Birthday = DateTime.Now.AddYears(-10),
                    Sex = i % 2
                };
                tm.Childrens.Add(model);
                AddChilds(model, intCount - 1);
            }
        }
24, table drop-down box

Enter image description

List<DataGridViewColumnEntity> lstCulumns = new List<DataGridViewColumnEntity>();
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "ID", HeadText = "Number", Width = 70, WidthType = SizeType.Absolute });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Name", HeadText = "Name", Width = 100, WidthType = SizeType.Absolute });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Age", HeadText = "Age", Width = 100, WidthType = SizeType.Absolute });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Birthday", HeadText = "Birthday", Width = 120, WidthType = SizeType.Absolute, Format = (a) => { return ((DateTime)a).ToString(" yyyy-MM-dd"); } });
lstCulumns.Add(new DataGridViewColumnEntity() { DataField = "Sex", HeadText = "Gender", Width = 100, WidthType = SizeType.Absolute, Format = (a) => { return ((int)a) == 0 ? "female": "male"; } });
this.ucComboxGrid1.GridColumns = lstCulumns;
List<object> lstSourceGrid = new List<object>();
For (int i = 0; i < 100; i++)
{
    TestModel model = new TestModel()
    {
        ID = i.ToString(),
        Age = 3 * i,
        Name = "name -" + i,
        Birthday = DateTime.Now.AddYears(-10),
        Sex = i % 2
    };
    lstSourceGrid.Add(model);
}
this.ucComboxGrid1.GridDataSource = lstSourceGrid;
25, TrackBar

Enter image description

输入图片说明

26, toolTips (toolTips)

Enter image description

HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "test prompt information \nLEFT", AnchorTipsLocation.LEFT);
HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "Test prompt information \nRIGHT", AnchorTipsLocation.RIGHT);
HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "Test prompt information \nTOP", AnchorTipsLocation.TOP);
HZH_Controls.Forms.FrmAnchorTips.ShowTips(button1, "Test prompt information \nBOTTOM", AnchorTipsLocation.BOTTOM);
26、LED Number

输入图片说明

27, scrolling text

Enter picture description Enter image description Enter image description

28, instrument

Enter image description

29, Pipeline

Enter image description

30, bottle

Enter image description

31, conveyor belt

Enter picture description

32、Valve

输入图片说明 输入图片说明

33、Blower

输入图片说明

34, signal light

Enter picture description

35、Alarm Lamp

输入图片说明

36、Temperature

输入图片说明

37、Mind Mapping

输入图片说明

38、icon

输入图片说明 输入图片说明

39、BarChart

输入图片说明

40、PieChart

输入图片说明

40、LineChart

输入图片说明 输入图片说明 输入图片说明

41、RadarChart

输入图片说明

42、LoadingSourceForm

输入图片说明

43、FunnelChart

输入图片说明

44、GraphicalOverlay

输入图片说明

45、VerificationForm

输入图片说明

46, sampling control

输入图片说明

Notice where the controls cross and there is no occlusion.
The control crops the effective work area according to the set drive to achieve no occlusion.

47、Shadow

输入图片说明

48、NavigationMenu

输入图片说明 输入图片说明 输入图片说明

49、SplitLabelLine

输入图片说明

50、TimeLine

输入图片说明

51、TransferData

输入图片说明

52、QuotePanel

输入图片说明

The last words

Finally, please like to click on the stars, if there are other commonly used controls, you can leave a message.

If you are useful to you, please reward me, thank you.

netwinformcontrol's People

Contributors

hbwhypw avatar kwwwvagaa avatar leoyounghub avatar mygithubxjw avatar w757703598 avatar zhaozhaoknight avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

netwinformcontrol's Issues

关于 LICENSE

代码仓库中是apache2.0的开源协议,但是nuget上下载是gpl,建议统一下

建议增加一个ComboGrid控件

image
建议增加一个类似于easyui的ComboGrid控件,可以显示多列,支持录入检索的功能,这个控件很实用,另外建议优化日期时间选择控件,使用感觉有点卡顿

关于UCdatagridview刷新问题

在原版的datagridview中可以变更绑定的数据源来达到自动刷新控件内容的目的

                var bs = new BindingSource();
                bs.DataSource = DataList;
                dgv_Demo.DataSource = DataList;
//然后使用如下语句即可完成控件内容刷新
dgv_Demo.Refresh();

更换这个之后这个就不好使了

现在只有给数据源重新赋值才可以达到这个效果了

可否添加一个类似流程图的导航菜单……

不知道楼主有没有碰到过类似流程图的模块导航菜单,这样具有先后顺序的操作模块就可以很直观的表现出来,让用户一眼就能看清一个整体的操作流程中包含了哪些小的或局部的流程。
流程图菜单的每个功能环节是一个可以单击,双击或右击的组件,每个环节之间有导航的箭头或连线连接,标识此环节在整个大流程中的位置……,整体样式有点类似已经发布的那个“管道”的视图控件,不过“管道”的每个接口环节可以接受UI交互

PanelTitle 中的layout类元素无法实时刷新,导致显示先前的内容

image

我在 PanelTitle 中放了个 TableLayout,当从另一个页面(比如代码页面)切换过来时,TableLayout 无法实时更新,而是会显示黑色的代码内容。

我分别在 Win10 和 win 7 中使用 visual studio 2015 复现该问题。

TableLayout 直接使用不会出现该问题。

添加一个 visual studio 2010 中的显示:

image

编译出来的程序有一样的问题。

2021年6月26日 补充:

当我在窗口上添加一个按钮,点击时刷新 UCPanelTitle,则点击后,内部的 TableLayout 能正常显示了。

感觉是某个地方没有及时刷新导致的。

以上。

在UcDataGridView控件中,当使用了自定义单元格,并加入按钮后,删除对应的行后,按钮动作会重复响应

在UcDataGridView控件中,当使用了自定义单元格,并加入按钮后,删除对应的行后,使用ReloadSource函数重新加载控件时,会导致用户控件消息处理函数重复加载,导致多次触发,代码如下

源代码UCDataGridViewRow.cs 193行-201行
foreach (Control item in this.panCells.Controls)
{
if (item is IDataGridViewCustomCell)
{
IDataGridViewCustomCell cell = item as IDataGridViewCustomCell;
//此处消息处理链未被清空,导致重复加载
cell.RowCustomEvent += cell_RowCustomEvent;
cell.SetBindSource(DataSource);
}
}

改为如下代码,貌似解决了这个问题

                // 获取事件信息
                EventInfo eventInfo = cell.GetType().GetEvent("RowCustomEvent");

                // 如果事件存在
                if (eventInfo != null)
                {
                    // 获取字段,该字段包含了已订阅的委托
                    FieldInfo fieldInfo = cell.GetType().GetField("RowCustomEvent", BindingFlags.Instance | BindingFlags.NonPublic);

                    if (fieldInfo != null)
                    {
                        // 获取已订阅的委托
                        MulticastDelegate multicastDelegate = fieldInfo.GetValue(cell) as MulticastDelegate;

                        if (multicastDelegate != null)
                        {
                            // 逐个取消订阅已订阅的委托
                            foreach (Delegate handler in multicastDelegate.GetInvocationList())
                            {
                                eventInfo.RemoveEventHandler(cell, handler);
                            }
                        }
                    }
                }
                cell.RowCustomEvent += cell_RowCustomEvent;
                cell.SetBindSource(DataSource);

ListView控件的一个小BUG

1.新建一个项目,引用HZH_Controls,将拖动1个Listview到窗体里,不设置Dock.Fill属性。
image

  1. 在FormLoad里添加代码:
    image

3.运行,提示错误:
image

4.经过测试,发现先将ListView设置一下Dock.Fill之后再运行就可以了。并且设置过之后再Dock.None也可以正确运行。。结论就是必须在Fill属性下运行过一次才行。作者能不能找下原因

Combobox items dual screen

Hello, thank you for good controls.
But i need help for issue in dual screen.
When main form at secondary screen combobox items showing first screen.

怎么安装使用

我是新手,您的这个控件不像其他vs插件一样可以直接安装进vs,不知道该如何启用您的控件

UnhandledException:System.InvalidCastException: 无法将类型为“HZH_Controls.Controls.TextBoxEx”的对象强制转换为类型“HZH_Controls.Controls.UCTextBoxEx”

private void uctextBox1_TextChanged(object sender, EventArgs e) { this.dataGridViewAxisDefine.CurrentCell.Value = ((HZH_Controls.Controls.UCTextBoxEx)sender).Text; this.uctextBox1.Visible = false; }

报这错:
UnhandledException:System.InvalidCastException: 无法将类型为“HZH_Controls.Controls.TextBoxEx”的对象强制转换为类型“HZH_Controls.Controls.UCTextBoxEx”。

HZH_Controls.Controls.UCTextBoxEx uctextBox1 = new HZH_Controls.Controls.UCTextBoxEx();

UCTextBoxEx是一个可以显示软键盘的TextBox控件

有没有一个好看的from基体

直接用原生的感觉不搭。demo用了frmWithTitle,也没发现有最大化最小化按钮之类的。而且那个X好丑。
能不能做一个基体?就是直接继承就比较好看那种。

step控件显示不正常

当step的显示名字长一点的时候,会导致后面的step显示不了或者不完整。
比如把现在的step1/step2/step3改成step1asdfsafaafasfsdfsdf,就会导致后面完全不显示了。

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.