本文整理汇总了C++中LayerMRI::GetWorldVoxelSize方法的典型用法代码示例。如果您正苦于以下问题:C++ LayerMRI::GetWorldVoxelSize方法的具体用法?C++ LayerMRI::GetWorldVoxelSize怎么用?C++ LayerMRI::GetWorldVoxelSize使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LayerMRI
的用法示例。
在下文中一共展示了LayerMRI::GetWorldVoxelSize方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: RespondTextTranslate
void DialogTransformVolume::RespondTextTranslate( int n )
{
if ( isVisible() )
{
bool bOK;
double dvalue =m_textTranslate[n]->text().toDouble(&bOK);
if ( bOK )
{
LayerMRI* layer = ( LayerMRI* )MainWindow::GetMainWindow()->GetActiveLayer( "MRI" );
if ( layer )
{
double pos[3];
layer->GetTranslate( pos );
pos[n] = dvalue;
layer->SetTranslate( pos );
MainWindow::GetMainWindow()->RequestRedraw();
double* vs = layer->GetWorldVoxelSize();
int range = m_scrollTranslate[n]->maximum();
m_scrollTranslate[n]->blockSignals(true);
m_scrollTranslate[n]->setValue(range/2 + (int)( pos[n] / vs[n] ) );
m_scrollTranslate[n]->blockSignals(false);
UpdateUI( 1 );
}
}
}
}
示例2: RespondScrollTranslate
void DialogTransformVolume::RespondScrollTranslate( int n )
{
if ( isVisible() )
{
LayerMRI* layer = ( LayerMRI* )MainWindow::GetMainWindow()->GetActiveLayer( "MRI" );
if ( layer )
{
double pos[3];
layer->GetTranslate( pos );
int range = m_scrollTranslate[n]->maximum();
int npos = m_scrollTranslate[n]->value();
double* vs = layer->GetWorldVoxelSize();
pos[n] = ( npos - range/2 ) * vs[n];
layer->SetTranslate( pos );
MainWindow::GetMainWindow()->RequestRedraw();
ChangeLineEditNumber(m_textTranslate[n], pos[n] );
UpdateUI( 1 );
}
}
}
示例3: OnButtonCenterToCursor
void DialogTransformVolume::OnButtonCenterToCursor()
{
if ( isVisible() )
{
LayerMRI* layer = ( LayerMRI* )MainWindow::GetMainWindow()->GetActiveLayer( "MRI" );
if ( layer )
{
double pos[3];
layer->GetSlicePosition(pos);
layer->SetTranslateByCenterPosition( pos );
MainWindow::GetMainWindow()->RequestRedraw();
double* vs = layer->GetWorldVoxelSize();
for (int n = 0; n < 3; n++)
{
int range = m_scrollTranslate[n]->maximum();
m_scrollTranslate[n]->blockSignals(true);
m_scrollTranslate[n]->setValue(range/2 + (int)( pos[n] / vs[n] ) );
m_scrollTranslate[n]->blockSignals(false);
}
UpdateUI( 0 );
}
}
}
示例4: UpdateUI
// scope: 0 => translate related, 1 => scale related, 2 => both
void DialogTransformVolume::UpdateUI( int scope )
{
LayerMRI* layer = (LayerMRI* )MainWindow::GetMainWindow()->GetActiveLayer( "MRI" );
if ( layer )
{
QList<QWidget*> allwidgets = this->findChildren<QWidget*>();
for ( int i = 0; i < allwidgets.size(); i++ )
{
allwidgets[i]->blockSignals( true );
}
if ( scope == 0 || scope == 2 )
{
double* vs = layer->GetWorldVoxelSize();
double* ws = layer->GetWorldSize();
double pos[3];
layer->GetTranslate( pos );
for ( int i = 0; i < 3; i++ )
{
int range = (int)( ws[i] / vs[i] + 0.5 ) * 2;
int npos = (int)(pos[i] / vs[i]) + range/2;
m_scrollTranslate[i]->setRange(0, range);
m_scrollTranslate[i]->setValue(npos);
ChangeLineEditNumber(m_textTranslate[i], pos[i]);
}
}
if ( scope == 1 || scope == 2 )
{
double scale[3];
layer->GetScale( scale );
for ( int i = 0; i < 3; i++ )
{
if ( scale[i] >= 1 )
{
m_scrollScale[i]->setValue( 50 + (int)( (scale[i]-1.0)*50 ) );
}
else
{
m_scrollScale[i]->setValue( 50 - (int)( (1.0-scale[i])*100 ) );
}
ChangeLineEditNumber(m_textScale[i], scale[i]);
}
}
ui->pushButtonRestore->setEnabled( layer->IsTransformed() );
ui->pushButtonSaveReg->setEnabled( layer->IsTransformed() );
ui->pushButtonSaveVolumeAs->setEnabled( layer->IsTransformed() );
double angle[3];
layer->GetRotate(angle);
ui->groupBoxAxis->setDisabled(angle[0] != 0 || angle[1] != 0 || angle[2] != 0);
for (int i = 0; i < 3; i++)
{
double val = angle[i];
while (val > 180)
val -= 360;
while (angle[i] < -180)
val += 360;
m_sliderRotate[i]->setValue((int)val);
ChangeLineEditNumber(m_textAngle[i], angle[i]);
}
for ( int i = 0; i < allwidgets.size(); i++ )
{
allwidgets[i]->blockSignals( false );
}
}
}