winform 位置不空 隐藏控件_WinForm操作隐藏的小知识点

本文介绍了在WinForm项目中使用CSkin库时遇到的两个问题及其解决方案。一是SKinDataGridView列排序混乱,原因是隐藏了某些列,解决办法是禁用列的自动排序;二是SKinDateTimePicker时间图标显示异常,是由于字体大小设置过大,调整字体大小即可正常显示。此外,还分享了窗体定位、禁止缩放、枚举类型转换等实用技巧。
摘要由CSDN通过智能技术生成

这次的项目需要使用Winform来实现,我们使用的是CSkin的皮肤。文章主要记录使用过程中遇到的小问题,也是楼主网上查找很久才找到的,这里总结下。

插件地址:

使用SKinDataGridView出现列乱排序问题

下面这张图是我在使用SKinDataGridView的界面,可以发现这个操作列没有在最后面,可是我在集合中分明是按照顺序来添加的,排序方式都一样的。

查找资料发现这个数据控件有点问题,最好不要让其自动的排序,除非是自己的查找列和展示的列名一致,这样才会正常显示,要是不一样就会像上面图片一样显示。(我这个就是因为ID和状态栏隐藏了,所以顺序就打乱了。)

下面这张图是我集合中的添加顺序

其实之前我一直在调整SortMode,这个上面显示是排序的顺序,但是一直出错。

经过多方查找终于找到了原因,其实就是之前上面说的哪样,栏目中又些隐藏了。那么我们就关闭其排序,不让其自动进行排序。代码如下:

//关掉列排序

skinGuidData.AutoGenerateColumns = false;

skinGuidData.DataSource = plService.GetPackagelistsByState();

F12到后台发现:其实是不让其自动排序。

这样就完美的解决了上面的问题。

时间控件SKinDataTimePicker显示右边时间图标

这个问题其实完全可以避免,但是我们在画页面的时候把里面的文本框的内容设置的太大了,导致此控件本身的时间图标不能正常显示。效果如下图所示:

下面这个是运行界面的效果,很是难受呀。导致我检查了很久才发现问题的所在。

原因:是因为我们把字体的font设置的太大了,导致把图标遮住了。所以才会出现上图的界面;

我们把这个设置未9pt就OK了。

窗体的几个常见操作

做技术一定要认真,一点小的失误都不允许。

窗体固定显示到正中央:

StartPosition:CenterScreen

不让其窗体放大放小:

FormBorderStyle :F开头的都可以

取消最大化,最小化:

MaximumBox:False

MinimizeBox:false

关于方法中可空类型的处理

是这样的,service方法中又很多参数是可空类型的,但是我们从前台接收到的是各种不能为空的类型。

之前的做法:没一次进行判断,不是可空的传递进去就OK。

service方法:

///

/// 通过日期,单位,快递公司进行分类查询

///

///

public IList GetPackagelistByDateOrCompanyOrStoreAddress(DateTime? startDate,DateTime? endDate,CourierCompany? courierCompany,StoreAddress? storeAddress)

{

var query = this.CrudPackagelist().Table().Where(x=>x.State==false); //从未取走的包裹中查找

if (startDate.HasValue || endDate.HasValue) // 或:一真为真

{

if (startDate.HasValue)

{

query = query.Where(x => x.CreateDate >startDate);

}

if (endDate.HasValue)

{

endDate = DateTime.Parse(endDate.Value.AddDays(1).ToString("yyyy-MM-dd 00:00:00"));

query = query.Where(x => x.CreateDate <=endDate); //这是查找某一特定时间的,这个还需要变化。

}

}

if (courierCompany.HasValue)

{

query = query.Where(x => x.CourierCompany == courierCompany);

}

if (storeAddress.HasValue)

{

query = query.Where(x => x.StoreAddress == storeAddress);

}

return query.OrderByDescending(x => x.CreateDate).ToList();

}

调用方法:

///

///未取包裹查询

///

///

///

private void skinButton2_Click(object sender, EventArgs e)

{

DateTime? startDate = null;

DateTime? endDate = null;

StoreAddress? storeAddressValue = null;

CourierCompany? courierCompanyValue = null;

try

{

if (!string.IsNullOrWhiteSpace(skinDate_UnclaimedStart.text))

{

startDate = DateTime.Parse(skinDate_UnclaimedStart.text);

}

if (!string.IsNullOrWhiteSpace(skinDate_UnclaimedEnd.text))

{

endDate = DateTime.Parse(skinDate_UnclaimedEnd.text);

}

if (skinStoreAddress.SelectedIndex != 0)

{

storeAddressValue = (StoreAddress)Enum.Parse(typeof(StoreAddress), ((ListItem)(skinStoreAddress.SelectedItem)).Text);

}

if (skinCourierCompany.SelectedIndex != 0)

{

courierCompanyValue = (CourierCompany)Enum.Parse(typeof(CourierCompany), ((ListItem)(skinCourierCompany.SelectedItem)).Text);

}

var resultList = plService.GetPackagelistByDateOrCompanyOrStoreAddress(startDate, endDate, courierCompanyValue, storeAddressValue);

skinNotTakeGuidData.DataSource = resultList;

}

catch (Exception ex)

{

Common.MsgBoxInfo("操作失败"+ex.Message);

}

}

一次封装,流程简化的过程

其实上面的代码都把一部分说明了,下面在说一下具体的场景,想从下面的下拉框中选择特定的值,传递后台进行选择查询。但是后台的方法参数是可空的,但是这里可空的转变有问题,不会像bs一样,很直接干脆。

关于枚举转换未下拉列表(SKinComboxBox)的操作:

Type courierCompany = typeof(CourierCompany);

this.skinCourierCompany.Items.Insert(0, "----请选择----");

foreach (int index in Enum.GetValues(courierCompany))

{

string name = Enum.GetName(courierCompany, index);

string value = index.ToString();

ListItem item = new ListItem();

item.Text = name;

item.Value = value;

this.skinCourierCompany.Items.Add(item);

}

this.skinCourierCompany.SelectedIndex = 0;

this.Show();

这里让下拉框第一个显示的是请选择,让直接插入第一个

后台的方法:

courierCompanyValue = (CourierCompany)Enum.Parse(typeof(CourierCompany), ((ListItem)(skinCourierCompany.SelectedItem)).Text);

这样就取到了选中的值,类型是枚举类型,但是要是选择请选择的话,这里的转换就会有错误。表示将可空类型转换不过去,报错误。

我们思路是先那取到的序号进行判断,要是是第一个那个就不进行转换,直接传递Null值就OK,不是就直接传递。下面是我之前的做法:

///

/// 查询事件

///

///

///

private void skinBtn_Accept_Click(object sender, EventArgs e)

{

//测试

StoreAddress storeAddressValue;

CourierCompany courierCompanyValue;

if (skinStoreAddress.SelectedIndex != 0 && skinCourierCompany.SelectedIndex != 0) //与:一假为假

{

storeAddressValue =(StoreAddress)Enum.Parse(typeof(StoreAddress), ((ListItem)(skinStoreAddress.SelectedItem)).Text);

courierCompanyValue =(CourierCompany)Enum.Parse(typeof(CourierCompany), ((ListItem)(skinCourierCompany.SelectedItem)).Text);

resultList = plService.GetPackagelistByDateOrCompanyOrStoreAddress(startDate, endDate, courierCompanyValue,storeAddressValue);

skinGuidData.DataSource = resultList;

return;

}if(skinCourierCompany.SelectedIndex !=0)

{

courierCompanyValue = (CourierCompany)Enum.Parse(typeof(CourierCompany), ((ListItem)(skinCourierCompany.SelectedItem)).Text);

}

if (skinStoreAddress.SelectedIndex != 0)

{

storeAddressValue = (StoreAddress)Enum.Parse(typeof(StoreAddress), ((ListItem)(skinStoreAddress.SelectedItem)).Text);

}

if (skinStoreAddress.SelectedIndex == 0 && skinCourierCompany.SelectedIndex != 0)

{

courierCompanyValue =

(CourierCompany)

Enum.Parse(typeof(CourierCompany), ((ListItem)(skinCourierCompany.SelectedItem)).Text);

resultList = plService.GetPackagelistByDateOrCompanyOrStoreAddress(startDate, endDate, courierCompanyValue,

null);

skinGuidData.DataSource = resultList;

return;

}

if (skinCourierCompany.SelectedIndex == 0 && skinStoreAddress.SelectedIndex != 0)

{

storeAddressValue = (StoreAddress)Enum.Parse(typeof(StoreAddress), ((ListItem)(skinStoreAddress.SelectedItem)).Text);

resultList = plService.GetPackagelistByDateOrCompanyOrStoreAddress(startDate, endDate,

null, storeAddressValue);

skinGuidData.DataSource = resultList;

return;

}

if (skinStoreAddress.SelectedIndex == 0 || skinCourierCompany.SelectedIndex == 0) //或:一真为真

{

resultList = plService.GetPackagelistByDateOrCompanyOrStoreAddress(startDate, endDate, null, null);

skinGuidData.DataSource = resultList;

return;

}

}

从之前的代码可以看到很多地方被复用了,没有一点高效代码的意思,在老大的帮助下,知道传递的可以是null值,那么我开始创建类型就赋值未null,要是没有变化就修改,要是有变化就直接传递变量,这样本来他就是Null,就不需要修改了。下面是修改后的代码:

///

///未取包裹查询

///

///

///

private void skinButton2_Click(object sender, EventArgs e)

{

DateTime? startDate = null;

DateTime? endDate = null;

StoreAddress? storeAddressValue = null;

CourierCompany? courierCompanyValue = null;

try

{

if (!string.IsNullOrWhiteSpace(skinDate_UnclaimedStart.text))

{

startDate = DateTime.Parse(skinDate_UnclaimedStart.text);

}

if (!string.IsNullOrWhiteSpace(skinDate_UnclaimedEnd.text))

{

endDate = DateTime.Parse(skinDate_UnclaimedEnd.text);

}

if (skinStoreAddress.SelectedIndex != 0)

{

storeAddressValue = (StoreAddress)Enum.Parse(typeof(StoreAddress), ((ListItem)(skinStoreAddress.SelectedItem)).Text);

}

if (skinCourierCompany.SelectedIndex != 0)

{

courierCompanyValue = (CourierCompany)Enum.Parse(typeof(CourierCompany), ((ListItem)(skinCourierCompany.SelectedItem)).Text);

}

var resultList = plService.GetPackagelistByDateOrCompanyOrStoreAddress(startDate, endDate, courierCompanyValue, storeAddressValue);

skinNotTakeGuidData.DataSource = resultList;

}

catch (Exception ex)

{

Common.MsgBoxInfo("操作失败"+ex.Message);

}

}

是不是简单多了,就不需要我之前那样一直进行判断了。

要理解编码是一个多思考,多动手的工作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值