我有一个使用SpreadsheetGear的WorkbookView控件的C#应用程序。用户希望能够对保存的单元格的注释进行更改。
有人知道在用户编辑评论时捕获更改的方法。编辑评论时不会触发单元格编辑事件,我找不到任何方法来捕获用户对评论所做的更改。
答案 0 :(得分:3)
在我读回Joe的回复并不知道单独保存注释的方法之前,我决定通过循环遍历工作簿View中的单元格来保存注释,并在表单关闭时抓取注释。
在看到他的回复之后,我找到了一种方法,在使用workbookView1_ShapeSelectionChanged和workbookView1_ShapeAction事件的组合输入后立即获得评论。打开注释框进行编辑以及关闭注释框进行编辑时,将触发workbookView1_ShapeSelectionChanged事件。当它为评论框打开时触发,我得到ActiveCell,因为当评论框关闭时它可能不再是ActiveCell。如果评论已更改,我会在评论框关闭时使用该单元格来获取评论。每次在注释框中输入新字符时,都会触发workbookView1_ShapeAction事件,这对于将注释标记为已更改非常有用。保存注释后,commentChanged变量将设置回false。以下是使用Joe在其答案中发布的代码的代码:
private void workbookView1_ShapeAction(object sender, SpreadsheetGear.Windows.Forms.ShapeActionEventArgs e)
{
switch (e.ShapeActionType)
{
case SpreadsheetGear.Windows.Forms.ShapeActionType.TextChanged:
if (e.Shape.Type == SpreadsheetGear.Shapes.ShapeType.Comment)
{
//set comment changed flag to true
_commentChanged = true;
}
break;
}
}
private void workbookView1_ShapeSelectionChanged(object sender, SpreadsheetGear.Windows.Forms.ShapeSelectionChangedEventArgs e)
{
if (_commentChanged)
{
//get comment
string comment = _commentCell.Comment.Shape.TextFrame.Characters.Text;
//save comment
//....
//set comment changed flag to false
_commentChanged = false;
}
else
{
//get the cell whose comment is being edited
_commentCell = workbookView1.ActiveCell;
}
}
答案 1 :(得分:1)
不幸的是,答案是“有点但不是真的”。
您可以捕获ShapeAction事件,如下所示,但ShapeAction事件实际上是为形状而不是注释设计的,因此您无法获取当前文本(文本尚未存储在形状中),您甚至无法获得评论所属的单元格。不过,我会粘贴一些代码,因为它可能对您有用:
private void workbookView1_ShapeAction(object sender, SpreadsheetGear.Windows.Forms.ShapeActionEventArgs e)
{
switch (e.ShapeActionType)
{
case SpreadsheetGear.Windows.Forms.ShapeActionType.TextChanged:
if (e.Shape.Type == SpreadsheetGear.Shapes.ShapeType.Comment)
{
// Unfortunately, this is as far as we can get since IShape
// does not have a way to get back to the cell which owns the comment.
//
// Furthermore, the text is not yet stored in the IShape, so we
// cannot get the current text either.
}
break;
}
}
如果您向SpreadsheetGear的支持部门发送电子邮件,要求此功能,他们会将此功能请求添加到其列表中,并附上您的电子邮件地址。