c#窗体添加toolStripDropDown控件,利用DropDowItem属性设置10种肤色名选项(详细步骤及代码编写)

对于初学c#窗体控件非常友好的,添加toolStripDropDown控件,利用DropDowItem属性设置10种肤色名选项——>

步骤如下:

在“工具箱”中找到ToolStrip控件,拖到窗体内

 

点击DropDownButton

 

双击DropDownItems属性,在弹出的项集合编译器点击“添加”

 

可以添加多个、修改属性值

 效果如下:

 代码如下:

toolStripDropDown控件中10种肤色名选项对应事件代码统一为一个事件代码,事件中根据Tag索引值而换相应皮肤

private void toolStripMenuItem_Click(object sender, EventArgs e)

        {

            ToolStripMenuItem tsmi = (ToolStripMenuItem)sender;
            int index=Convert.ToInt32(tsmi.Tag);
            string skinname = "",
                switch(index)
            {
                case 0:
                    skinname = "0.ssk";
                    break;
                case 1:
                    skinname = "1.ssk";
                    break;
                case 2:
                    skinname = "2.ssk";
                    break;
                case 3:
                    skinname = "3.ssk";
                    break;
                case 4:
                    skinname = "4.ssk";
                    break;
                case 5:
                    skinname = "5.ssk";
                    break;
                case 6:
                    skinname = "6.ssk";
                    break;
                case 7:
                    skinname = "7.ssk";
                    break;
                case 8:
                    skinname = "8.ssk";
                    break;
                case 9:
                    skinname = "9.ssk";
                    break;
                default:
                    skinname = "";
                    break;
            }
            GetSkin(skinname);
        }
        private void GetSkin(string skinName)
        {
            skin.SkinFile = Application.StartupPath + @"\skin\" + skinName;
            skin.Active = true;
            skin.SkinAllForm = true;
        }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以尝试在 `DateTimePicker` 的 `DropDown` 事件中自定义下拉控件。在自定义的下拉控件添加一个 `DataGridView` 控件,并设置其 `DataSource` 属性为一个包含日期和对应周数的数据源。 以下是代码示例: ```csharp private void dateTimePicker1_DropDown(object sender, EventArgs e) { // 创建一个自定义控件,用于替换 DateTimePicker 的默认下拉控件 CustomDropDown dropDown = new CustomDropDown(); // 创建一个 DataGridView 控件,用于显示日期和对应周数 DataGridView dgv = new DataGridView(); dgv.Dock = DockStyle.Fill; dgv.AutoGenerateColumns = false; // 添加日期列 DataGridViewTextBoxColumn dateColumn = new DataGridViewTextBoxColumn(); dateColumn.DataPropertyName = "Date"; dateColumn.HeaderText = "日期"; dgv.Columns.Add(dateColumn); // 添加周数列 DataGridViewTextBoxColumn weekColumn = new DataGridViewTextBoxColumn(); weekColumn.DataPropertyName = "Week"; weekColumn.HeaderText = "周数"; dgv.Columns.Add(weekColumn); // 绑定数据源 dgv.DataSource = GetDataSource(); // 将 DataGridView 添加到自定义控件dropDown.Controls.Add(dgv); // 将自定义控件显示在 DateTimePicker 下方 dropDown.Show(dateTimePicker1, new Point(0, dateTimePicker1.Height)); } // 返回包含日期和对应周数的数据源 private DataTable GetDataSource() { DataTable dt = new DataTable(); dt.Columns.Add("Date", typeof(DateTime)); dt.Columns.Add("Week", typeof(int)); // 假设需要显示当前月份的日期和对应周数 DateTime currentDate = DateTime.Now; int currentMonth = currentDate.Month; int currentYear = currentDate.Year; DateTime startDate = new DateTime(currentYear, currentMonth, 1); DateTime endDate = startDate.AddMonths(1).AddDays(-1); // 计算每一天的周数,并添加到数据源中 for (DateTime date = startDate; date <= endDate; date = date.AddDays(1)) { int week = GetWeekOfYear(date); dt.Rows.Add(date, week); } return dt; } // 计算指定日期的周数 private int GetWeekOfYear(DateTime date) { CultureInfo ci = CultureInfo.CurrentCulture; CalendarWeekRule cwr = ci.DateTimeFormat.CalendarWeekRule; DayOfWeek dow = ci.DateTimeFormat.FirstDayOfWeek; return ci.Calendar.GetWeekOfYear(date, cwr, dow); } // 自定义下拉控件 private class CustomDropDown : ToolStripDropDown { public CustomDropDown() { // 设置下拉控件的样式 this.AutoSize = false; this.DoubleBuffered = true; this.ResizeRedraw = true; this.Padding = new Padding(0); } protected override void OnPaint(PaintEventArgs e) { // 绘制下拉控件的背景 e.Graphics.Clear(this.BackColor); base.OnPaint(e); } } ``` 请注意,以上代码仅提供了一实现思路,您可以根据具体需求进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值