15

我正在使用 Windows 窗体使用 c# 和 Microsoft 报告查看器生成身份证。一切正常,除了我在 Microsoft 报表查看器中找不到列重复方向。

当前情景

我的报告纸尺寸是 A4。每页最多可显示 10 张单独的卡片。页面有 2 列。每列显示 5 张卡片。如图所示,它正在生成卡片。列重复方向是垂直的。它首先列出第一列 (1-5),然后列出第二列 (6-10)。

在此处输入图像描述

我的要求

我希望报告列重复方向是水平的,如下图所示。首先显示 1,然后显示 2 和 3 和 4,依此类推。

在此处输入图像描述

为什么我要水平显示而不是垂直显示?

它将节省纸张。例如,如果用户按照当前场景仅生成 4 张身份证,它将在第 1 列中生成 4 张身份证,并且整个页面空间都被浪费了,因为我无法重新使用剩余的空间。

通过将列方向重复为水平,将显示 4 张卡片,如在第 1 列中显示卡片 1 和 3,在第 2 列中将显示卡片 2 和 4。然后我可以剪纸并在以后重复使用。

我搜索了很多,但找不到任何解决方案。任何建议、评论或链接都会有所帮助。我不能使用任何其他报告。提前致谢。

4

3 回答 3

8

创建矩阵

将您的行分组定义为

=Ceiling(Fields!CardNo.Value/2)

将列分组定义为

=Fields!CardNo.Value Mod 2

您的报告设计将如下所示。外部组仅出于说明目的而显示,但您可以将其删除。

在此处输入图像描述

现在,当您运行报告时。你会得到你正在寻找的结果

在此处输入图像描述

没有任何分组页眉和页脚。您的报告输出将是

在此处输入图像描述

于 2016-01-21T15:26:19.910 回答
1

这个问题可以看作是映射问题,您需要重新排列您的项目,如下所示:

n -> f(n)
----------
1 -> 1
2 -> 6
3 -> 2
4 -> 7
5 -> 3
6 -> 8
7 -> 4
8 -> 9
9 -> 5
10 -> 10

n is the original position
f(n) is the mapped position

可以看出它遵循这样的模式:

  1. f(n) = floor(n / 2) + 1 如果 n 是奇数
  2. f(n) = (10 + n) / 2如果 n 是偶数

因此,您可能希望按照以下方式重新调整您放置物品的顺序。这是index从 0-9 给出的项目(从 0 开始遵循 C# 典型数字索引器),您可以执行以下操作:

index++;
int newIndex = index % 2 == 0 ? (10 + index) / 2 : index / 2 + 1;
newIndex--;

你应该能够Cards正确放置你的。

注意:没有给出实际代码,这是为了说明如何从概念上解决问题。

于 2016-01-21T12:28:56.423 回答
1

另一个答案。这将在您的桌子上使用或不使用组。

在您的报告上并排放置两个表格。将第一个表设置为从第一条记录开始分区并跳过 1 的查询。接下来,将第二个表设置为从第二条记录开始跳过 1 的分区的查询。

于 2016-01-21T15:32:56.543 回答