注意:该问题无效,我犯了一个完全不同的错误,请参阅最后的编辑。
我只想使用vtkSTLReader类读取STL文件。我的代码如下所示:
vtkSmartPointer<vtkSTLReader> reader = vtkSmartPointer<vtkSTLReader>::New();
reader->SetFileName(path.c_str());
reader->Update();
vtkSmartPointer<vtkPolyData> poly_data = reader->GetOutput();
然后代码继续显示多边形数据。
这在某种程度上起作用。照原样的代码将忽略path
文件名之外的所有内容,然后在我执行程序的任何位置查找该文件。
例如,如果我喜欢在控制台中调用path = /home/local/users/myusername/file.stl
该程序/some_path/somefolder/myprogram
时将其放置在中/some_path/
,则该程序仅在(且仅)在有文件的副本时才有效/some_path/file.stl
。
如果我改为从内部执行程序/some_path/somefolder
,则只有在有程序的情况下,它才有效/some_path/somefolder/file.stl
。
我什至去尝试了如果添加一行代码会发生什么情况
path = "/dsgsdmklgmoeg/" + path;
结果完全一样。
正如我的路径所暗示的,我在Linux下工作。
我尝试说明上面的绝对路径,从执行位置开始的相对路径以及从可执行文件开始的相对路径(以防万一)。
对于相对路径,我尝试了各种我认为可能需要的变体,带前导./
,有无前导/
。
对于绝对路径,我尝试将所有斜杠替换为反斜杠,因为它可能会使用Windows样式路径。
我意识到一种快速的解决方法是将文件简单地复制到所需的位置,但这肯定不是永久的解决方案。
有人对此有经验吗?这是vtk的特点吗?
如果这很重要,我使用vtk 5.6.1(由于某些兼容性要求,无法切换到更高版本)。
编辑:我意识到,我做了一个很简单的错误,而不是path.c_str()
我file.c_str()
在我的原代码,有file
是从一个变量path
组装。键入上面的代码时我没有犯错,使问题无效。
出于好奇,我深入研究了github。
这是我发现的:
VTK/vtkSTLReader.cxx
在v5.6.1(int vtkSTLReader::RequestData()
,第96 ... 110行):
if (!this->FileName || (this->FileName && (0==strlen(this->FileName))))
{
vtkErrorMacro(<<"A FileName must be specified.");
this->SetErrorCode( vtkErrorCode::NoFileNameError );
return 0;
}
// Initialize
//
if ((fp = fopen(this->FileName, "r")) == NULL)
{
vtkErrorMacro(<< "File " << this->FileName << " not found");
this->SetErrorCode( vtkErrorCode::CannotOpenFileError );
return 0;
}
VTK/vtkSTLReader.h
在v5.6.1(第57 ... 60行):
// Description:
// Specify file name of stereo lithography file.
vtkSetStringMacro(FileName);
vtkGetStringMacro(FileName);
VTK/vtkSetGet.h
在v5.6.1(第88 ... 122行):
//
// Set character string. Creates member Set"name"()
// (e.g., SetFilename(char *));
//
#define vtkSetStringMacro(name) \
virtual void Set##name (const char* _arg) \
{ \
vtkDebugMacro(<< this->GetClassName() << " (" << this << "): setting " << #name " to " << (_arg?_arg:"(null)") ); \
if ( this->name == NULL && _arg == NULL) { return;} \
if ( this->name && _arg && (!strcmp(this->name,_arg))) { return;} \
if (this->name) { delete [] this->name; } \
if (_arg) \
{ \
size_t n = strlen(_arg) + 1; \
char *cp1 = new char[n]; \
const char *cp2 = (_arg); \
this->name = cp1; \
do { *cp1++ = *cp2++; } while ( --n ); \
} \
else \
{ \
this->name = NULL; \
} \
this->Modified(); \
}
//
// Get character string. Creates member Get"name"()
// (e.g., char *GetFilename());
//
#define vtkGetStringMacro(name) \
virtual char* Get##name () { \
vtkDebugMacro(<< this->GetClassName() << " (" << this << "): returning " << #name " of " << (this->name?this->name:"(null)")); \
return this->name; \
}
查看这段代码(恕我直言,这是OP发行的相关代码),我找不到任何提示,指出从给出的文件路径中删除了目录SetFileName()
。
我不知道实际上是什么会导致OP问题,即仅考虑当前目录中的文件。但是,我很难相信VTK可以为此受到指责。
因此,我建议在上方和下方进行进一步搜索:
SetFileName()
正确吗?(简单的部分)fopen()
(或在中称为fopen()
)引起的吗?本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句