我在 ImageDisplay 组件中遇到了箭头注释问题。当我按顺序创建箭头注释时,箭头坐标是正确的。但是,如果我先创建一个注释组,然后将箭头注释添加到该组,箭头坐标就会变得不正确。似乎标记组的坐标系可能与 ImageDisplay 使用的坐标系不匹配。
我尝试过的:
- 逐个生成箭头标记按预期工作。
Image img := RealImage("RImg",4,256,256)
img.ShowImage()
ImageDisplay img_disp = img.ImageGetImageDisplay(0)
ImageDocument img_doc = img.ImageGetOrCreateImageDocument()
Number radius = 50
Number cx = 128
Number cy = 128
Number flag = 1
for (Number count = 0 ; count < 4 ; count++)
{
Number phi = count * 2 * Pi()/ 4
Number px = round(cx+radius*Cos(phi))
Number py = round(cy+radius*Sin(phi))
Component arrow = NewArrowAnnotation(cy, cx, py, px)
img_disp.ComponentAddChildAtEnd(arrow)
}
- 首先创建标记组,然后添加箭头标记会导致坐标混淆。
Image img := RealImage("RImg",4,256,256)
img.ShowImage()
ImageDisplay img_disp = img.ImageGetImageDisplay(0)
ImageDocument img_doc = img.ImageGetOrCreateImageDocument()
Component arrows = NewGroupAnnotation()
Number radius = 50
Number cx = 128
Number cy = 128
for (Number count = 0 ; count < 4 ; count++)
{
Number phi = count * 2 * Pi()/ 4
Number px = round(cx+radius*Cos(phi))
Number py = round(cy+radius*Sin(phi))
Result(py + ", " + px + "\n")
Component arrow = NewArrowAnnotation(cy, cx, py, px)
arrows.ComponentAddChildAtEnd(arrow)
}
img_disp.ComponentAddChildAtEnd(arrows)
问题:
- 什么原因可能导致标记组和 ImageDisplay 之间的坐标差异?
- 添加箭头标记时,如何确保标记组使用与 ImageDisplay 相同的坐标系?
我对各种类型的子组件如何继承坐标系统的细节非常不清楚,而且我在 DM 文档中找不到任何地方完整地阐述这一点。也许有人可以给我们一个更清晰的解释。
然而,很明显,组注释没有自己明确定义的坐标系,因此向组中添加新的(以前未放置的)注释通常不会产生所需的结果。更好的方法似乎是首先将新注释放置在所需的 ImageDisplay 上,然后将这些放置的注释添加到组中,以实现所需的子组件关联,如下所示: