VSTO(C#)Excel开发6:与窗体交互

初级代码游戏的专栏介绍与文章目录-CSDN博客

我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。

这些代码大部分以Linux为目标但部分代码是纯C++的,可以在任何平台上使用。

源码指引:github源码指引_初级代码游戏的博客-CSDN博客


前一篇VSTO(C#)Excel开发5:调整表格到一页-CSDN博客

本篇来研究一下与窗体交互,也就是与普通的C#窗体代码协作。当我们能与普通的C#代码协作我们就可以说可以把原来的程序和Excel整合在一起了。

目录

一、创建一个窗体

二、修改功能区按钮代码来显示窗体

三、效果

四、C#form窗体的基本操作

五、在窗体上显示内容


一、创建一个窗体

项目上右键-添加-新建项:

选"窗体(Windows窗体)",名称可以改可以不改,无关紧要。 我用的名字是"FormFitToOnePage.cs",生成的类就是FormFitToOnePage。

二、修改功能区按钮代码来显示窗体

功能区按钮我们已经很熟悉了,新建或者直接在原来的上面改都行。在功能区的代码里添加如下代码:

功能区的类名我改成了"RibbonFitToOnePage"。第一个红框的代码可以让开发工具自动添加,第二个红框是在类里面添加窗体变量,第三个红框是在功能区加载时创建窗体对象,第四个红框就是在点击按钮时把窗体显示出来。

为了方便你验证(Ctrl-C、Ctrl-V),上面几句代码如下:

cs 复制代码
using System.Windows.Forms;
using Microsoft.Office.Tools.Ribbon;

namespace ctExcelTools
{
    public partial class RibbonFitToOnePage
    {
        private FormFitToOnePage formFitToOnePage;
		private void RibbonFitToOnePage_Load(object sender, RibbonUIEventArgs e)
        {
			formFitToOnePage = new FormFitToOnePage();
		}

		private void button1_Click(object sender, RibbonControlEventArgs e)
		{
			formFitToOnePage.TopMost = true;
			formFitToOnePage.Show();

三、效果

添这几句代码应该没什么风险,编译运行点击按钮:

窗体能够显示,窗体的内容我们后面再说。

任务栏上是这样的:

也就是说通过功能区显示的窗体和Excel是可以来回切换的。

四、C#form窗体的基本操作

C#窗体比MFC方便,但也有些奇怪,form.Show()其实是无模式对话框,点右上角红叉关闭的话对话框就没有了,不能重复显示,为此需要处理FormClosing事件,在事件里写如下代码:

cs 复制代码
		private void FormFitToOnePage_FormClosing(object sender, FormClosingEventArgs e)
		{
            e.Cancel = true;
            this.Hide();
		}

先取消关闭事件,然后隐藏窗体,这样就能在用Show来显示了。但是第二次显示的窗体不会显示在顶层,因此需要在显示之前设置为顶层:

cs 复制代码
			formFitToOnePage.TopMost = true;
			formFitToOnePage.Show();

但是这样一来永远在顶层,会遮住我们要看的内容,所以又要在显示之后取消顶层,这样才能把窗口放到后面去,我在按钮事件的最后取消了窗体的顶层显示。

五、在窗体上显示内容

窗体上增加一个文本框(这不是本主题的内容),因为我们的程序功能很简单,所以把文本框对象改成public就可以在功能区代码里直接使用了:

添了一个textbox,改了一下Anchor属性,四边绑定,也就是随着窗体大小伸缩,设置为多行和只读。

红框那一句是窗体设计器添加的,但是是"private",改成"public"就可以了。

功能区按钮的事件代码如下:

cs 复制代码
		private void button1_Click(object sender, RibbonControlEventArgs e)
		{
			formFitToOnePage.TopMost = true;
			formFitToOnePage.Show();

			string str = "开始操作。。。。。。\r\n";
			try
			{
				Worksheet worksheet = Globals.ThisAddIn.Application.ActiveSheet;
				Range usedRange = worksheet.UsedRange;
				str += " UsedRange:" + usedRange.Address + "\r\n";
				str += " UsedRange.Column:" + usedRange.Column + "\r\n";
				str += " UsedRange.Columns.Count:" + usedRange.Columns.Count + "\r\n";
				str += " UsedRange.Row:" + usedRange.Row + "\n";
				str += " UsedRange.Rows.Count:" + usedRange.Rows.Count + "\r\n";
				str += " PrintArea:" + worksheet.PageSetup.PrintArea + "\r\n";
				str += " PaperSize:" + worksheet.PageSetup.PaperSize.ToString() + "\r\n";
				str += " ChartSize:" + worksheet.PageSetup.ChartSize + "\r\n";
				str += " Orientation:" + worksheet.PageSetup.Orientation.ToString() + "\r\n";
				str += " TopMargin:" + worksheet.PageSetup.TopMargin + "\r\n";
				str += " BottomMargin:" + worksheet.PageSetup.BottomMargin + "\r\n";
				str += " LeftMargin:" + worksheet.PageSetup.LeftMargin + "\r\n";
				str += " RightMargin:" + worksheet.PageSetup.RightMargin + "\r\n";
				str += " Pages:" + worksheet.PageSetup.Pages.Count + "\r\n";

				//worksheet.PageSetup.Zoom = false;//设置为false才能Fit
				//worksheet.PageSetup.FitToPagesWide = 1;

				double originalTotalWidth = 0;
				double originalTotalHeigh = 0;

				for (int i = 0; i < usedRange.Columns.Count; ++i)
				{
					Range colum = worksheet.Columns[usedRange.Column + i];
					originalTotalWidth += colum.ColumnWidth;
				}
				for (int i = 0; i < usedRange.Rows.Count; ++i)
				{
					Range row = worksheet.Rows[usedRange.Row + i];
					originalTotalHeigh += row.RowHeight;
				}
				str += " originalTotalWidth:" + originalTotalWidth + "\r\n";
				str += " originalTotalHeigh:" + originalTotalHeigh + "\r\n";

				str += "操作成功完成\n";
			}
			catch (Exception ex)
			{
				formFitToOnePage.textBox_Info.Text += ex.ToString();
			}
			formFitToOnePage.textBox_Info.Text += str;
			formFitToOnePage.TopMost = false;
		}

就是把上一篇显示的内容输出到窗体的文本框里了。

现在可以切换窗口、关闭窗口、点击按钮重新显示,注意,窗口的文本是追加,会越来越多,也能因此确认窗口只是隐藏了。


下一篇VSTO(C#)Excel开发7:自定义任务窗格-CSDN博客


(这里是文档结束)

相关推荐
玩泥巴的3 小时前
存储那么贵,何不白嫖飞书云文件空间
c#·.net·二次开发·飞书
脑电信号要分类13 小时前
将多张图片拼接成一个pdf文件输出
pdf·c#·apache
njsgcs14 小时前
c# solidworks 折弯系数检查
开发语言·c#
格林威15 小时前
工业相机图像采集:Grab Timeout 设置建议——拒绝“假死”与“丢帧”的黄金法则
开发语言·人工智能·数码相机·计算机视觉·c#·机器视觉·工业相机
唐青枫15 小时前
C#.NET SignalR + Redis Backplane 深入解析:多节点部署与跨实例消息同步
c#·.net
FL16238631291 天前
[C#][winform]segment-anything分割万物部署onnx模型一键抠图演示
开发语言·c#
love530love1 天前
OpenClaw 手机直连配置全流程
人工智能·windows·python·智能手机·c#·agent·openclaw
bcbobo21cn1 天前
C# byte类型和byte数组的使用
开发语言·c#·字节数组·byte类型
月巴月巴白勺合鸟月半1 天前
一次PDF文件的处理(一)
pdf·c#
大鹏说大话1 天前
Java 锁膨胀机制深度解析:从偏向锁到重量级锁的进化之路
开发语言·c#