void CDemoView::OnSendmessagePmctlgetfile() // // Display information about the current file. { if (! Validate()) { return; } PAN_CtlFileInfo fi; if (! SendMsg(PM_CTLGETFILE, 0, (LPARAM)(PAN_CtlFileInfo * ) &fi)) { return; } m_pWndOut->SendToOutput("PM_CTLGETFILE:\r"); switch (fi.type) { case PAN_RasterFile : m_pWndOut->SendToOutput("type: RASTER FILE"); break; case PAN_VectorFile : m_pWndOut->SendToOutput("type: VECTOR FILE"); break; case PAN_DatabaseFile : m_pWndOut->SendToOutput("type: DATABASE FILE"); break; case PAN_SpreadsheetFile : m_pWndOut->SendToOutput("type: SPREADSHEET FILE"); break; case PAN_DocumentFile : m_pWndOut->SendToOutput("type: DOCUMENT FILE"); break; case PAN_ArchiveFile : m_pWndOut->SendToOutput("type: ARCHIVE FILE"); break; } /* switch */ m_pWndOut->SendToOutput("name: %s", fi.name); m_pWndOut->SendToOutput("size: %ld", fi.size); time_t currentDate = fi.date; m_pWndOut->SendToOutput("date: %s", ctime(¤tDate)); m_pWndOut->SendToOutput("desc: %s", fi.desc); // display the dimensions PAN_CtlRange* rg = &fi.dimensions; switch (fi.type) { case PAN_VectorFile: m_pWndOut->SendToOutput("dim : %.2lf x %.2lf x %.2lf\r", rg->max.x - rg->min.x, rg->max.y - rg->min.y, rg->max.z - rg->min.z); break; case PAN_RasterFile: m_pWndOut->SendToOutput("dim : %.2lf x %.2lf\r", rg->max.x - rg->min.x, rg->max.y - rg->min.y); break; default: m_pWndOut->SendToOutput("dim : %.2lf x %.2lf\r", rg->max.x - rg->min.x , rg->max.y - rg->min.y); } m_pWndOut->SendToOutput("colr: %d (bits)", fi.colorDepth); m_pWndOut->SendToOutput("nbPg: %d", fi.nPages); if ( fi.type == PAN_RasterFile ) { m_pWndOut->SendToOutput("tiles: %d x %d", fi.tilex, fi.tiley); } if ( fi.ins.offset.x !=0 || fi.ins.offset.y !=0 || fi.ins.offset.z != 0 || fi.ins.scale.x !=0 || fi.ins.scale.y !=0 || fi.ins.scale.z != 0 ) { m_pWndOut->SendToOutput("Insertion data:\n"); m_pWndOut->SendToOutput(" Point: (%.2lf, %.2lf, %.2lf)", fi.ins.offset.x, fi.ins.offset.y, fi.ins.offset.z); m_pWndOut->SendToOutput(" Scaling: (%.2lf, %.2lf, %.2lf)", fi.ins.scale.x, fi.ins.scale.y, fi.ins.scale.z); m_pWndOut->SendToOutput(" Resolution: (%.2lf, %.2lf, %.2lf)", fi.ins.dpi.x, fi.ins.dpi.y, fi.ins.dpi.z); m_pWndOut->SendToOutput(" Rotation: %.2lf radians", fi.ins.rot); } }
时间: 2024-04-18 08:26:14 浏览: 136
这段代码是一个处理`OnSendmessagePmctlgetfile`命令消息的函数。它用于显示当前文件的信息。下面是代码的详细解释:
1. 首先,通过调用`Validate()`函数来验证当前视图的有效性,如果无效则返回。
2. 创建一个`PAN_CtlFileInfo`对象`fi`,用于存储控件文件的信息。
3. 调用`SendMsg()`函数发送`PM_CTLGETFILE`消息,并将`fi`的地址作为参数传递给消息处理函数,以获取控件文件的信息。如果发送消息失败,则返回。
4. 使用`m_pWndOut->SendToOutput()`函数将"PM_CTLGETFILE:"输出到日志输出窗口。
5. 根据文件类型(`fi.type`)使用`switch`语句,将文件类型的相关信息输出到日志输出窗口。
6. 使用`m_pWndOut->SendToOutput()`函数将文件的名称、大小、日期和描述等信息输出到日志输出窗口。
7. 根据文件类型,使用`switch`语句处理尺寸(dimensions)的输出。对于矢量文件(PAN_VectorFile),输出三维尺寸;对于栅格文件(PAN_RasterFile),输出二维尺寸;对于其他类型的文件,输出二维尺寸。
8. 使用`m_pWndOut->SendToOutput()`函数将颜色深度、页数和瓦片大小(仅适用于栅格文件)等信息输出到日志输出窗口。
9. 如果文件的插入数据(fi.ins)中存在偏移、缩放或旋转等信息,则使用`m_pWndOut->SendToOutput()`函数将插入数据的相关信息输出到日志输出窗口。
总之,这段代码用于获取并显示当前控件文件的信息,包括文件类型、名称、大小、日期、描述、尺寸、颜色深度等。它将这些信息输出到日志输出窗口,以便进行调试或查看文件的详细信息。
阅读全文