c# farpoint GetPreferredRowHeight 获取完美高度后后好多 换行空格
时间: 2023-11-27 11:49:50 浏览: 64
根据您提供的信息,我理解您在使用 Farpoint 控件中的 GetPreferredRowHeight 方法时,获取到的单元格内容存在换行和空格的问题。这可能是因为该方法返回的是单元格中所包含的文本的完美高度,而文本中的换行和空格也会占据一定的高度。
如果您想要去掉换行和空格,可以使用 String 类中的 Trim() 和 Replace() 方法。例如,您可以在获取完单元格内容后,使用以下代码进行处理:
```csharp
string cellText = mySheet.Cells[row, col].Text; // 获取单元格内容
cellText = cellText.Trim().Replace("\r\n", "").Replace(" ", ""); // 去除换行和空格
int preferredHeight = mySheet.Rows[row].GetPreferredHeight(); // 获取完美高度
```
在上述代码中,Trim() 方法可以去除字符串首尾的空格,Replace() 方法可以将字符串中的换行和空格替换为空字符串。这样处理后,获取到的完美高度就不会包含换行和空格所占据的高度了。
相关问题
c# farpoint 单元格 wrodwrap 避免 括号换行
如果您使用的是 FarPoint 的 WinForms 控件,可以考虑在单元格中使用自定义绘制来解决此问题。您可以从 FpSpread 控件的 CellType 属性中选择 Custom,然后在程序中实现自定义绘制逻辑。
在自定义绘制逻辑中,您可以遍历单元格文本中的每个字符,并在必要时手动插入换行符(例如在左括号和右括号之间不进行换行)。然后,您可以使用 Graphics 对象进行文本绘制,并将其输出到单元格中。
下面是一些示例代码,用于在 FarPoint FpSpread 控件的自定义单元格类型中实现包含自定义绘制逻辑的单元格:
```csharp
using FarPoint.Win.Spread.CellType;
using FarPoint.Win.Spread.DrawingSpace;
using System.Drawing;
public class CustomWrapCellType : TextCellType
{
public override void Paint(Graphics g, Rectangle r, object value)
{
string text = value as string;
if (text == null) return;
// 计算行高和列宽
int lineHeight = (int)g.MeasureString(text, this.Font).Height;
int columnWidth = r.Width;
// 遍历每个字符并插入换行符
for (int i = 0; i < text.Length; i++)
{
char c = text[i];
if (c == '(' && i < text.Length - 1 && text[i + 1] == ')')
{
// 避免在括号内部换行
continue;
}
if (c == ' ' && i < text.Length - 1 && text[i + 1] == '(')
{
// 避免在括号前面换行
continue;
}
if (c == ')' && i > 0 && text[i - 1] == '(')
{
// 避免在括号后面换行
continue;
}
if (c == '\r' || c == '\n')
{
// 如果文本中已经包含换行符,则不需要再插入
continue;
}
if (g.MeasureString(text.Substring(0, i + 1), this.Font).Width > columnWidth)
{
// 当前行已经超出列宽,需要插入换行符
text = text.Insert(i, Environment.NewLine);
i += Environment.NewLine.Length;
}
}
// 绘制文本
using (StringFormat sf = new StringFormat())
{
sf.Alignment = StringAlignment.Near;
sf.LineAlignment = StringAlignment.Near;
sf.FormatFlags = StringFormatFlags.NoWrap;
RectangleF rect = new RectangleF(r.Left, r.Top, columnWidth, lineHeight);
g.DrawString(text, this.Font, new SolidBrush(this.ForeColor), rect, sf);
}
}
}
```
使用以上代码,您可以将包含自定义绘制逻辑的单元格类型应用于 FpSpread 控件中特定的单元格。例如:
```csharp
FpSpread spread = new FpSpread();
SheetView sheet = spread.ActiveSheet;
CustomWrapCellType cellType = new CustomWrapCellType();
sheet.Cells[0, 0].CellType = cellType;
sheet.Cells[0, 0].Value = "这是一段包含括号的文本(不会换行)";
sheet.Cells[1, 0].CellType = cellType;
sheet.Cells[1, 0].Value = "这是一段包含括号的文本,(但是括号前后不会换行)";
sheet.Cells[2, 0].CellType = cellType;
sheet.Cells[2, 0].Value = "这是一段较长的文本,将会自动换行,但不会在括号内部换行。如果文本中已经包含换行符,则不会再插入。";
```
以上代码将在 FpSpread 控件的第一列中显示三个单元格,每个单元格包含不同形式的文本,并使用自定义绘制逻辑进行换行处理。
c# farpoint 单元格 高度自适应
在 FarPoint 的单元格中,可以使用 AutoFitRows 方法来自适应行高。以下是一个示例代码片段,演示如何使用该方法:
```csharp
fpSpread1.ActiveSheet.Rows.AutoFitRows();
```
此代码将自适应当前工作表中所有行的高度。如果要自适应特定行的高度,则可以使用类似以下代码的方法:
```csharp
fpSpread1.ActiveSheet.Rows[0].AutoFitHeight();
```
此代码将自适应第一行的高度。可以将索引更改为所需的行号。
请注意,自适应行高可能会影响 FarPoint 控件的性能,因此建议仅在必要时使用此功能。
阅读全文