winform自定义按钮菜单

   //填写其他报表按钮
        private void btnWriteRep_Click(object sender, EventArgs e)
        {
            try
            {
                Point p1 = new Point();
                Point p = this.btnWriteRep.Location;

p1.X = p.X;
                p1.Y = p.Y + btnWriteRep.Height;
                contextmenustrip.Show(this.flowLayoutPanel3, p1);              
            }
            catch (Exception ex)
            {

}
        }
        //加载填写其他报表下拉按钮菜单
        private bool LoadDropButton()
        {
            try
            {
                contextmenustrip = new ContextMenuStrip();//下拉菜单
                contextmenustrip.Font = new Font("宋体", 10f);
                List<ReportListItem> reportlist = basedeclar.GetReportListItem("Y");
                foreach (ReportListItem rep in reportlist)
                {
                    contextmenustrip.Items.Add(AddMenu("[" + rep.Bbzt_mc + "]" + rep.Name, rep.Value, rep.Bbzt_mc));
                }
                //分隔线
                ToolStripSeparator line = new ToolStripSeparator();
                contextmenustrip.Items.Add(line);

contextmenustrip.Items.Add(AddMenu("选择更多报表......", "", ""));
                contextmenustrip.ItemClicked += new ToolStripItemClickedEventHandler(contextmenustrip_ItemClicked);
                return true;
            }
            catch (Exception e)
            {
                MessageBox.Show("加载按钮(填写其他报表)菜单失败");
                return false;
            }
        }
        //下拉项单击事件
        void contextmenustrip_ItemClicked(object sender, ToolStripItemClickedEventArgs e)
        {
            try
            {
                if (isChanged)
                {
                    if (MessageBox.Show("数据有变化,是否保存", "提示", MessageBoxButtons.YesNo) == DialogResult.Yes)
                    {
                        btnSave_Click(sender, null);
                    }
                    else
                    {
                        //LoadAxCellData();
                        axCell1.ReadFromBuffer(PreBytes);                       
                    }
                    isChanged = false;
                }
                //选择更多报表显示所有报表
                if (e.ClickedItem.Text.Contains("选择更多报表"))
                {
                    isCloseMenu = true;
                    contextmenustrip.Items.RemoveAt(contextmenustrip.Items.Count - 1);
                    List<ReportListItem> reportlist = basedeclar.GetReportListItem("N");
                    foreach (ReportListItem rep in reportlist)
                    {
                        contextmenustrip.Items.Add(AddMenu("[" + rep.Bbzt_mc + "]" + rep.Name, rep.Value, rep.Bbzt_mc));
                    }
                    contextmenustrip.Closing += new ToolStripDropDownClosingEventHandler(contextmenustrip_Closing);
                }
                else
                {
                    isCloseMenu = false;
                    //axCell1.SetSheetVisible(axCell1.GetCurSheet(), false);
                    //axCell1.SetSheetVisible(axCell1.GetSheetIndex(e.ClickedItem.Name), true);
                    axCell1.SetCurSheet(axCell1.GetSheetIndex(e.ClickedItem.Name));                   
                }
            }
            catch (Exception ex)
            {

}
        }
        //下拉菜单关闭判断是否关闭
        void contextmenustrip_Closing(object sender, ToolStripDropDownClosingEventArgs e)
        {
            if (isCloseMenu)
            {
                if (e.CloseReason == ToolStripDropDownCloseReason.AppClicked || e.CloseReason == ToolStripDropDownCloseReason.Keyboard)
                    e.Cancel = false;
                else
                    e.Cancel = true;
            }
        }

时间: 2024-10-08 07:02:56

winform自定义按钮菜单的相关文章

quick-cocos2d-x学习笔记【6】——制作自定义效果按钮菜单

前面提到的是基本的菜单使用,还是很容易的,不过我们在商业产品中,经常看到的按钮都是非常好看,不光光是图片做得精美,而且动画效果也很棒.Candy Crash都玩过吧,看它们那个按钮,真的像果冻一样,效果确实很赞,所以我们也来做个,当然不是它那个效果,而且点击之后有一个抖动的效果.像这样, 好了,开始做个吧,我这个也是搬了一下coinflip中的按钮代码,算是学习一下. 创建一个views文件夹,里面创建一个MyButton.lua文件,这个就是我们的自定义按钮类了.实现的原理比较简单,在ui.n

轻量级web富文本框——wangEditor使用手册(3)——如何自定义配置菜单

1. 引言 上一节<轻量级web富文本框——wangEditor使用手册(2)——扩展一个“缩进”功能>最后提到,新建的菜单不能只是默认放在菜单的后面,应该可以自定义的放在当前菜单栏中的任何位置.这一节就讲述wangEditor目前支持的几种自定义配置菜单的使用. 下载地址:https://github.com/wangfupeng1988/wangEditor demo演示:http://www.cnblogs.com/wangfupeng1988/p/4185508.html 交流QQ群:

django xadmin 插件(3) 列表视图新增自定义按钮

效果图: 编辑按钮是默认的list_editable属性对应的插件(xadmin.plugins.editable) 放大按钮对应的是自定义插件. 自定义按钮源码: xplugin.py(保证能够直接或者间接被adminx.py引用到即可) # -*- coding:utf-8 -*- import xadmin from xadmin.views import BaseAdminPlugin, ListAdminView from xadmin.views.edit import ModelF

winform自定义皮肤思路

声明: 思路来自于网上源码,具体作者不清楚了,大家可以搜索Paway.Windows.Forms. 一.去掉边框 this.FormBorderStyle = FormBorderStyle.None; 二.绘制基本元素 1.基本元素:图标.标题.窗口控制(最小化.最大化.关闭). 2.如何绘制:重写OnPaint,在制定区域绘制基本元素. 3.异形窗口:比如圆角矩形,在OnResize中指定重绘区域,如果区域为矩形,重绘出的窗口就是圆角矩形了. 三.窗口控制区域鼠标动作 当以上工作完成后,一个

wordpress优化之结合prism.js为编辑器自定义按钮转化代码

原文链接 http://ymblog.net/2016/07/24/wordpress-prism/ 继昨天花了一天一夜的时间匆匆写了主题Jiameil3.0之后,心中一直在想着优化加速,体验更好,插件更少,到目前为止,博客插件有多说,Crayon Syntax Highlighter代码高亮插件,super cache缓存插件,百度sitemap.在没有缓存的情况下,首页dom初识加载完成(不是document加载完成)的时间为5-6s左右,有缓存的情况下大概为2s左右,觉得慢了,查看源码,发

Winform 实现像菜单一样弹出层

原文:Winform 实现像菜单一样弹出层 在实际工作中,如果能像菜单一样弹出自定义内容,会方便很多,比如查询时,比如下拉列表显示多列信息时,比如在填写某个信息需要查看一些信息树时.这个时候自定义弹出界面就显的非常重要了 我这里其实用到的是网上找到的一个控件(下载地址),控件可以把你装载的任何对象显示出来(这里的对象是指:窗体,自定义控件等),这里文章写出来并不是为了炫耀什么,只是觉得发现些好东西就分享出来而已,同时也做个记录,方便以后查找 开始正文,这里我做一个多列下拉列表来说明: 1.新建w

SharePoint开发 - 自定义导航菜单(一)菜单声明与配置

本篇描述自定义sharepoint菜单的一种方式,自定义菜单适用于一些门户等需求的网站 自定义的菜单有自己的数据源,可以是数据表,可以是XML,本篇叙述的是采用XML数据源作为菜单的声明定义部分,将XML以文件的格式保存到网站中自己创建的配置文档库中 XML菜单的格式形如下面的格式,其中有菜单标题title属性,有菜单所属的权限用户组SPGroups属性,有菜单的链接url属性,实际应用中可以添加更多的字段. <SiteMap> <SiteMapNode title="我的项目

按钮配置之自定义按钮使用(一)——JEPLUS软件快速开发平台

JEPLUS按钮配置之自定义按钮使用(一) 系统开发过程中无论是表单的默认按钮或是列表的默认按钮以及Action的默认按钮有时候并不能满足我们的业务需求,这个时候就需要我们来自己定义一些按钮来实现我们的业务需求,今天这个笔记就讲解一下我们应该如何自定义按钮以及如何为自定义按钮添加功能逻辑需求. 一.自定义按钮的效果展示 二.自定义按钮的显示样式配置 1.打开功能菜单的配置界面点击"按钮配置"进入功能的按钮配置界面 2.输入按钮的编码时必须要保证按钮的编码必须是唯一,见名知意的命名是最好

Python使用Flask框架,结合Highchart,自定义导出菜单项目及顺序

参考链接: https://www.highcharts.com.cn/docs/export-module-overview https://api.hcharts.cn/highcharts#exporting.chartOptions 图表导出模块是指提供了将网页中图表导出为常见的图片格式(PNG.JPG.SVG) 或 PDF 文档的功能模块,另外导出模块还提供了直接在网页中打印图表的功能. 图表的导出默认是提交数据(SVG 字符串或图表配置 JSON 字符串 )到导出服务器上进行生成图片