@ -58,6 +58,7 @@ namespace MWRender
mIsNearest ( false ) ,
mIsNearest ( false ) ,
mHeight ( 124.f ) ,
mHeight ( 124.f ) ,
mBaseCameraDistance ( Settings : : Manager : : getFloat ( " third person camera distance " , " Camera " ) ) ,
mBaseCameraDistance ( Settings : : Manager : : getFloat ( " third person camera distance " , " Camera " ) ) ,
mUseSeparatePreviewCam ( Settings : : Manager : : getBool ( " separate preview camera " , " Camera " ) ) ,
mVanityToggleQueued ( false ) ,
mVanityToggleQueued ( false ) ,
mVanityToggleQueuedValue ( false ) ,
mVanityToggleQueuedValue ( false ) ,
mViewModeToggleQueued ( false ) ,
mViewModeToggleQueued ( false ) ,
@ -126,7 +127,7 @@ namespace MWRender
osg : : Vec3d Camera : : getFocalPointOffset ( ) const
osg : : Vec3d Camera : : getFocalPointOffset ( ) const
{
{
osg : : Vec3d offset ( 0 , 0 , 10.f ) ;
osg : : Vec3d offset ( 0 , 0 , 10.f ) ;
if ( ! m PreviewMode & & ! mVanity . enabled )
if ( ! m UseSeparatePreviewCam | | ( ! m PreviewMode & & ! mVanity . enabled ) )
{
{
offset . x ( ) + = mFocalPointCurrentOffset . x ( ) * cos ( getYaw ( ) ) ;
offset . x ( ) + = mFocalPointCurrentOffset . x ( ) * cos ( getYaw ( ) ) ;
offset . y ( ) + = mFocalPointCurrentOffset . x ( ) * sin ( getYaw ( ) ) ;
offset . y ( ) + = mFocalPointCurrentOffset . x ( ) * sin ( getYaw ( ) ) ;
@ -322,17 +323,19 @@ namespace MWRender
processViewChange ( ) ;
processViewChange ( ) ;
float offset = mPreviewCam . offset ;
if ( mUseSeparatePreviewCam )
{
if ( mVanity . enabled ) {
float offset = mPreviewCam . offset ;
setPitch ( osg : : DegreesToRadians ( - 30.f ) ) ;
if ( mVanity . enabled )
mMainCam . offset = mCameraDistance ;
{
} else {
setPitch ( osg : : DegreesToRadians ( - 30.f ) ) ;
offset = mMainCam . offset ;
mMainCam . offset = mCameraDistance ;
}
else
offset = mMainCam . offset ;
mCameraDistance = offset ;
}
}
mCameraDistance = offset ;
return true ;
return true ;
}
}
@ -347,16 +350,18 @@ namespace MWRender
mPreviewMode = enable ;
mPreviewMode = enable ;
processViewChange ( ) ;
processViewChange ( ) ;
float offset = mCameraDistance ;
if ( mUseSeparatePreviewCam )
if ( mPreviewMode ) {
{
mMainCam . offset = offset ;
float offset = mCameraDistance ;
offset = mPreviewCam . offset ;
if ( mPreviewMode ) {
} else {
mMainCam . offset = offset ;
mPreviewCam . offset = offset ;
offset = mPreviewCam . offset ;
offset = mMainCam . offset ;
} else {
mPreviewCam . offset = offset ;
offset = mMainCam . offset ;
}
mCameraDistance = offset ;
}
}
mCameraDistance = offset ;
}
}
void Camera : : setSneakOffset ( float offset )
void Camera : : setSneakOffset ( float offset )
@ -366,7 +371,7 @@ namespace MWRender
float Camera : : getYaw ( ) const
float Camera : : getYaw ( ) const
{
{
if ( mVanity . enabled | | mPreviewMode )
if ( mUseSeparatePreviewCam & & ( mVanity . enabled | | mPreviewMode ) )
return mPreviewCam . yaw ;
return mPreviewCam . yaw ;
return mMainCam . yaw ;
return mMainCam . yaw ;
}
}
@ -378,18 +383,16 @@ namespace MWRender
} else if ( angle < - osg : : PI ) {
} else if ( angle < - osg : : PI ) {
angle + = osg : : PI * 2 ;
angle + = osg : : PI * 2 ;
}
}
if ( m Vanity. enabled | | mPreviewMode ) {
if ( m UseSeparatePreviewCam & & ( m Vanity. enabled | | mPreviewMode ) )
mPreviewCam . yaw = angle ;
mPreviewCam . yaw = angle ;
} else {
else
mMainCam . yaw = angle ;
mMainCam . yaw = angle ;
}
}
}
float Camera : : getPitch ( ) const
float Camera : : getPitch ( ) const
{
{
if ( m Vanity. enabled | | mPreviewMode ) {
if ( m UseSeparatePreviewCam & & ( m Vanity. enabled | | mPreviewMode ) )
return mPreviewCam . pitch ;
return mPreviewCam . pitch ;
}
return mMainCam . pitch ;
return mMainCam . pitch ;
}
}
@ -397,7 +400,7 @@ namespace MWRender
{
{
const float epsilon = 0.000001f ;
const float epsilon = 0.000001f ;
float limit = osg : : PI_2 - epsilon ;
float limit = osg : : PI_2 - epsilon ;
if ( m PreviewMode)
if ( m UseSeparatePreviewCam & & m PreviewMode)
limit / = 2 ;
limit / = 2 ;
if ( angle > limit )
if ( angle > limit )
@ -405,11 +408,10 @@ namespace MWRender
else if ( angle < - limit )
else if ( angle < - limit )
angle = - limit ;
angle = - limit ;
if ( m Vanity. enabled | | mPreviewMode ) {
if ( m UseSeparatePreviewCam & & ( m Vanity. enabled | | mPreviewMode ) )
mPreviewCam . pitch = angle ;
mPreviewCam . pitch = angle ;
} else {
else
mMainCam . pitch = angle ;
mMainCam . pitch = angle ;
}
}
}
float Camera : : getCameraDistance ( ) const
float Camera : : getCameraDistance ( ) const
@ -428,7 +430,7 @@ namespace MWRender
if ( adjust )
if ( adjust )
{
{
if ( m Vanity. enabled | | mPreviewMode )
if ( m UseSeparatePreviewCam & & ( m Vanity. enabled | | mPreviewMode ) )
dist + = mCameraDistance ;
dist + = mCameraDistance ;
else
else
dist + = std : : min ( mCameraDistance - getCameraDistanceCorrection ( ) , mBaseCameraDistance ) ;
dist + = std : : min ( mCameraDistance - getCameraDistanceCorrection ( ) , mBaseCameraDistance ) ;
@ -443,7 +445,7 @@ namespace MWRender
mIsNearest = true ;
mIsNearest = true ;
}
}
if ( m Vanity. enabled | | mPreviewMode )
if ( m UseSeparatePreviewCam & & ( m Vanity. enabled | | mPreviewMode ) )
mPreviewCam . offset = dist ;
mPreviewCam . offset = dist ;
else if ( ! mFirstPersonView )
else if ( ! mFirstPersonView )
{
{
@ -482,7 +484,7 @@ namespace MWRender
void Camera : : setCameraDistance ( )
void Camera : : setCameraDistance ( )
{
{
if ( m Vanity. enabled | | mPreviewMode )
if ( m UseSeparatePreviewCam & & ( m Vanity. enabled | | mPreviewMode ) )
mCameraDistance = mPreviewCam . offset ;
mCameraDistance = mPreviewCam . offset ;
else if ( ! mFirstPersonView )
else if ( ! mFirstPersonView )
{
{