<html>
<head>
<style>
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 10pt;
font-family:Verdana
}
</style>
</head>
<body class='hmmessage'>
<br>Hello, everyone.<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; I am recently studying volume rendering in VTK, but when compiling a program I met some curious problems, and I have tried to solve it but failed at last. hope someone can tell me how to solve it.<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; This is the error when compiling(on Fedora 9).<br><br>[albert@localhost Cxxbin]$ make<br>Linking CXX executable VolumeExample<br>CMakeFiles/VolumeExample.dir/VolumeExample.cxx.o: In function `main':<br>VolumeExample.cxx:(.text+0x309): undefined reference to `vtkVolumeRayCastCompositeFunction::New()'<br>VolumeExample.cxx:(.text+0x311): undefined reference to `vtkVolumeRayCastMapper::New()'<br>collect2: ld returned 1 exit status<br>make[2]: *** [VolumeExample] Error 1<br>make[1]: *** [CMakeFiles/VolumeExample.dir/all] Error 2<br>make: *** [all] Error 2<br><br><br>And here is the related code!!<br><br><br>#include "vtkActor.h"<br>#include "vtkPolyDataMapper.h"<br>#include "vtkRenderer.h"<br>#include "vtkRenderWindow.h"<br>#include "vtkRenderWindowInteractor.h"<br>#include "vtkProperty.h"<br><br>#include "vtkImageData.h"<br>#include "vtkVolume16Reader.h"<br>#include "vtkPiecewiseFunction.h"<br>#include "vtkColorTransferFunction.h"<br>#include "vtkVolumeRayCastCompositeFunction.h"<br>#include "vtkVolumeRayCastMapper.h"<br>#include "vtkVolumeProperty.h"<br>#include "vtkVolume.h"<br>#include "vtkOutlineFilter.h"<br>#include "vtkPlanes.h"<br><br><br>int main(){<br>&nbsp;&nbsp;&nbsp; vtkVolume16Reader *v16 = vtkVolume16Reader::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; v16-&gt;SetDataDimensions(64, 64);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; v16-&gt;GetOutput()-&gt;SetOrigin(0.0, 0.0, 0.0);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; v16-&gt;SetDataByteOrderToLittleEndian();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; v16-&gt;SetFilePrefix("./quarter/");<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; v16-&gt;SetImageRange(1, 93);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; v16-&gt;SetDataSpacing(3.2, 3.2, 1.5);<br><br>&nbsp;&nbsp;&nbsp; vtkPiecewiseFunction *tfun = vtkPiecewiseFunction::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(70.0, 0.0);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(599.0, 0.0);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(600.0, 0.0);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(1195.0, 0.0);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(1200.0, 0.2);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(2000.0, 0.3);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tfun-&gt;AddPoint(4095.0, 1.0);<br><br>&nbsp;&nbsp;&nbsp; vtkColorTransferFunction *ctfun = vtkColorTransferFunction::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ctfun-&gt;AddRGBPoint(0.0, 0.5, 0.0, 0.0);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ctfun-&gt;AddRGBPoint(600.0, 1.0, 0.5, 0.5);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ctfun-&gt;AddRGBPoint(1280.0, 0.9, 0.2, 0.3);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ctfun-&gt;AddRGBPoint(1960.0, 0.81, 0.27, 0.1);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ctfun-&gt;AddRGBPoint(4095.0, 0.5, 0.5, 0.5);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br>&nbsp;&nbsp;&nbsp; vtkVolumeRayCastCompositeFunction *compositeFunction = vtkVolumeRayCastCompositeFunction::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br>&nbsp;&nbsp;&nbsp; vtkVolumeRayCastMapper *volumeMapper = vtkVolumeRayCastMapper::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; volumeMapper-&gt;SetInputConnection(v16-&gt;GetOutputPort());<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; volumeMapper-&gt;SetVolumeRayCastFunction(compositeFunction);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br><br>&nbsp;&nbsp;&nbsp; vtkVolumeProperty *volumeProperty = vtkVolumeProperty::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; volumeProperty-&gt;SetColor(ctfun);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; volumeProperty-&gt;SetScalarOpacity(tfun);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //volumeProperty-&gt;SetInterPolationTypeToLinear();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; volumeProperty-&gt;ShadeOn();<br><br>&nbsp;&nbsp;&nbsp; vtkVolume *newvol = vtkVolume::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; newvol-&gt;SetMapper(volumeMapper);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; newvol-&gt;SetProperty(volumeProperty);<br>&nbsp; &nbsp;<br>&nbsp;&nbsp;&nbsp; vtkOutlineFilter *outline = vtkOutlineFilter::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; outline-&gt;SetInputConnection(v16-&gt;GetOutputPort());<br><br>&nbsp;&nbsp;&nbsp; vtkPolyDataMapper *outlineMapper = vtkPolyDataMapper::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; outlineMapper-&gt;SetInputConnection(outline-&gt;GetOutputPort());<br><br>&nbsp;&nbsp;&nbsp; vtkActor *outlineActor = vtkActor::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; outlineActor-&gt;SetMapper(outlineMapper);<br><br>&nbsp;&nbsp;&nbsp; vtkRenderer *ren1 = vtkRenderer::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br>&nbsp;&nbsp;&nbsp; vtkRenderWindow *renWin = vtkRenderWindow::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; renWin-&gt;AddRenderer(ren1);<br><br>&nbsp;&nbsp;&nbsp; vtkRenderWindowInteractor *iren = vtkRenderWindowInteractor::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; iren-&gt;SetRenderWindow(renWin);<br><br>&nbsp;&nbsp;&nbsp; //vtkBoxWidget *boxWidget = vtkBoxWidget::New();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //boxWidget-&gt;SetInteractor(iren);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //boxWidget-&gt;SetPlaceFactor(1.0);<br><br>&nbsp;&nbsp;&nbsp; ren1-&gt;AddActor(outlineActor);<br>&nbsp;&nbsp;&nbsp; ren1-&gt;AddVolume(newvol);<br><br><br>&nbsp;&nbsp;&nbsp; //boxWidget-&gt;SetInput(v16-&gt;GetOutput());<br>&nbsp;&nbsp;&nbsp; //boxWidget-&gt;PlaceWidget();<br>&nbsp;&nbsp;&nbsp; //boxWidget-&gt;InsideOutOn();<br>&nbsp;&nbsp;&nbsp; iren-&gt;Initialize();<br>&nbsp;&nbsp;&nbsp; iren-&gt;Start();<br>&nbsp; &nbsp;<br>}<br><br><br><br>Hope anyone can help me! Thanks in advance!<br><br><br /><hr />更多热辣资讯尽在新版MSN首页! <a href='http://cn.msn.com/' target='_new'>立刻访问!</a></body>
</html>