+ for (int i=0; i<mCurrentSlicerManager->NumberOfSlicers(); i++) {
+ mCurrentSlicerManager->GetSlicer(i)->ForceUpdateDisplayExtent();
+ mCurrentSlicerManager->GetSlicer(i)->Render();
+ }
+}
+//------------------------------------------------------------------------------
+
+//------------------------------------------------------------------------------
+ void vvToolRigidReg::UpdateTextEditor(vtkMatrix4x4 *matrix,QTextEdit* textEdit)
+{
+ QFont font=QFont("Times New Roman",11);
+ textEdit->setCurrentFont(font);
+ textEdit->update();
+
+ QString str1,str2,str3;
+ QColor color;
+ textEdit->clear();
+ textEdit->setAcceptRichText(true);
+ str2=textEdit->toPlainText();
+ str2.append("#Rotation Center(mm): \n#");
+ textEdit->setText(str2);
+
+ str2=textEdit->toPlainText();
+ textEdit->setTextColor(QColor(255,0,0));
+ str2.append(str3.append(Xval->text()));
+ textEdit->setText(str2);
+ str3.clear();
+
+ str2=textEdit->toPlainText();
+ str2.append("\t");
+ textEdit->setText(str2);
+
+ str2=textEdit->toPlainText();
+ str2.append(str3.append(Yval->text()));
+ textEdit->setText(str2);
+ str3.clear();
+
+ str2=textEdit->toPlainText();
+ str2.append("\t");
+ textEdit->setText(str2);
+
+
+ str2=textEdit->toPlainText();
+ str2.append(str3.append(Zval->text()));
+ textEdit->setText(str2);
+
+
+ str2=textEdit->toPlainText();
+ str2.append("\n");
+ textEdit->setText(str2);
+
+
+ str2=textEdit->toPlainText();
+ str2.append("#Transformation Matrix(mm):\n");
+ textEdit->setText(str2);
+ for(int i=0;i<4;i++)
+ {
+ for(int j=0;j<4;j++)
+ {
+ str2=textEdit->toPlainText();
+ // str2.append("\t"+str1.setNum(matrix->Element[i][j]));
+ str2.append(QString("%1\t").arg(str1.setNum(matrix->Element[i][j]),2));
+ textEdit->setText(str2);
+ }
+ str2=textEdit->toPlainText();
+ str2.append("\n");
+ textEdit->setText(str2);
+ }
+ //QString str = QFileDialog::getOpenFileName();
+ textEdit->setTextColor(QColor(255,0,0));
+ textEdit->setFont(QFont("courrier new",12,4,true));
+ textEdit->toPlainText().toAscii();
+
+ str2=textEdit->toPlainText();
+ textEdit->setText(str2);
+}
+//------------------------------------------------------------------------------
+
+//------------------------------------------------------------------------------
+void vvToolRigidReg::UpdateTransform_sliders()
+{
+ InitializeSliders(xtrans_slider->value()*mInput1->GetImage()->GetSpacing()[0],
+ ytrans_slider->value()*mInput1->GetImage()->GetSpacing()[1],
+ ztrans_slider->value()*mInput1->GetImage()->GetSpacing()[2],
+ xrot_slider->value(),yrot_slider->value(),zrot_slider->value(),false);
+ UpdateTransform(true);
+ Render();
+}
+//------------------------------------------------------------------------------
+
+//------------------------------------------------------------------------------
+void vvToolRigidReg::UpdateTransform_sb()
+{
+ InitializeSliders(xtrans_sb->value(),
+ ytrans_sb->value(),
+ ztrans_sb->value(),
+ xrot_sb->value(),yrot_sb->value(),zrot_sb->value(),false);
+ UpdateTransform(false);
+ Render();
+}
+//------------------------------------------------------------------------------
+
+//------------------------------------------------------------------------------
+void vvToolRigidReg::AutoRegister()
+{
+ GetArgsInfoFromGUI();
+ //clitk::AffineRegistrationGenericFilter::Pointer filter =
+ // clitk::AffineRegistrationGenericFilter::New();
+ //filter->SetArgsInfo(mArgsInfo);
+ // filter->Update();
+
+}
+//------------------------------------------------------------------------------
+
+//------------------------------------------------------------------------------
+void vvToolRigidReg::UpdateTransform(bool slider_enabled)
+{
+ vtkSmartPointer<vtkTransform> transform_final=vtkSmartPointer<vtkTransform>::New();
+ transform_final->SetMatrix(mInitialMatrix);
+ transform_final->PostMultiply();
+ //Rotations
+ double x=0, y=0 ,z=0;
+ x= Xval->text().toDouble();
+ y= Yval->text().toDouble();
+ z= Zval->text().toDouble();
+ transform_final->Translate(-x,-y,-z);
+ if(slider_enabled){
+ transform_final->RotateY(yrot_slider->value());
+ transform_final->RotateX(xrot_slider->value());
+ transform_final->RotateZ(zrot_slider->value());
+ }
+ else{
+ transform_final->RotateY(yrot_sb->value());
+ transform_final->RotateX(xrot_sb->value());
+ transform_final->RotateZ(zrot_sb->value());
+ }
+ transform_final->Translate(x,y,z);
+ transform_final->PreMultiply();
+ if(slider_enabled){
+ transform_final->Translate(xtrans_slider->value()*mInput1->GetImage()->GetSpacing()[0],0,0);
+ transform_final->Translate(0,ytrans_slider->value()*mInput1->GetImage()->GetSpacing()[1],0);
+ transform_final->Translate(0,0,ztrans_slider->value()*mInput1->GetImage()->GetSpacing()[2]);
+ }
+ else{
+ transform_final->Translate(xtrans_sb->value(),0,0);
+ transform_final->Translate(0,ytrans_sb->value(),0);
+ transform_final->Translate(0,0,ztrans_sb->value());
+ }
+ SetTransform(transform_final->GetMatrix());
+ UpdateTextEditor(transform_final->GetMatrix(),textEdit);
+}
+//------------------------------------------------------------------------------
+