void CChoreoGlobalEventWidget::DrawLabel( CChoreoWidgetDrawHelper& drawHelper, COLORREF clr, int x, int y, bool right ) { CChoreoEvent *event = GetEvent(); if ( !event ) return; int len = drawHelper.CalcTextWidth( "Arial", 9, FW_NORMAL, va( "%s", event->GetName() ) ); RECT rcText; rcText.top = y; rcText.bottom = y + 10; rcText.left = x - len / 2; rcText.right = rcText.left + len; if ( !right ) { drawHelper.DrawColoredTextCharset( "Marlett", 9, FW_NORMAL, SYMBOL_CHARSET, clr, rcText, "3" ); OffsetRect( &rcText, 8, 0 ); drawHelper.DrawColoredText( "Arial", 9, FW_NORMAL, clr, rcText, va( "%s", event->GetName() ) ); } else { drawHelper.DrawColoredText( "Arial", 9, FW_NORMAL, clr, rcText, va( "%s", event->GetName() ) ); OffsetRect( &rcText, len, 0 ); drawHelper.DrawColoredTextCharset( "Marlett", 9, FW_NORMAL, SYMBOL_CHARSET, clr, rcText, "4" ); } }
//----------------------------------------------------------------------------- // Purpose: // Input : drawHelper - // rcBounds - //----------------------------------------------------------------------------- void CChoreoEventWidget::redrawStatus( CChoreoWidgetDrawHelper& drawHelper, RECT& rcClient ) { if ( !getVisible() ) return; CChoreoEvent *event = GetEvent(); if ( !event ) return; int deflateborder = 1; int fontsize = 9; HDC dc = drawHelper.GrabDC(); // Now draw the label RECT rcEventLabel; rcEventLabel = rcClient; InflateRect( &rcEventLabel, 0, -deflateborder ); // rcEventLabel.top += 2; rcEventLabel.left += 2; //rcEventLabel.top = rcEventLabel.bottom - 2 * ( fontsize + 2 ) - 1; //rcEventLabel.bottom = rcEventLabel.top + fontsize + 2; int leftAdd = 16; if ( CChoreoEventWidget::GetImage( event->GetType() ) ) { mxbitmapdata_t *image = CChoreoEventWidget::GetImage( event->GetType() ); if ( image ) { RECT rcFixed = rcEventLabel; drawHelper.OffsetSubRect( rcFixed ); DrawBitmapToDC( dc, rcFixed.left, rcFixed.top, leftAdd, leftAdd, *image ); } } if ( event->IsResumeCondition() ) { RECT rc = rcEventLabel; OffsetRect( &rc, 16, 0 ); rc.right = rc.left + 16; RECT rcFixed = rc; drawHelper.OffsetSubRect( rcFixed ); DrawBitmapToDC( dc, rcFixed.left, rcFixed.top, rcFixed.right - rcFixed.left, rcFixed.bottom - rcFixed.top, *CChoreoEventWidget::GetPauseImage() ); } // Draw Type Name: //rcEventLabel.top -= 4; rcEventLabel.left = rcClient.left + 32; rcEventLabel.bottom = rcEventLabel.top + fontsize + 2; // OffsetRect( &rcEventLabel, 0, 2 ); int len = drawHelper.CalcTextWidth( "Arial", fontsize, FW_NORMAL, "%s event \"%s\"", event->NameForType( event->GetType() ), event->GetName() ); drawHelper.DrawColoredText( "Arial", fontsize, FW_NORMAL, COLOR_INFO_TEXT, rcEventLabel, "%s event \"%s\"", event->NameForType( event->GetType() ), event->GetName() ); OffsetRect( &rcEventLabel, 0, fontsize + 2 ); drawHelper.DrawColoredText( "Arial", fontsize, FW_NORMAL, COLOR_INFO_TEXT, rcEventLabel, "parameters \"%s\"", GetLabelText() ); }
//----------------------------------------------------------------------------- // Purpose: FIXME: This should either be embedded or we should draw the caption // here //----------------------------------------------------------------------------- void CChoreoEventWidget::redraw( CChoreoWidgetDrawHelper& drawHelper ) { if ( !getVisible() ) return; CChoreoEvent *event = GetEvent(); if ( !event ) return; int deflateborder = 1; int fontsize = 9; HDC dc = drawHelper.GrabDC(); RECT rcClient = getBounds(); RECT rcDC; drawHelper.GetClientRect( rcDC ); RECT dummy; if ( !IntersectRect( &dummy, &rcDC, &rcClient ) ) return; bool ramponly = m_pView->IsRampOnly(); if ( IsSelected() && !ramponly ) { InflateRect( &rcClient, 3, 1 ); //rcClient.bottom -= 1; rcClient.right += 1; RECT rcFrame = rcClient; RECT rcBorder = rcClient; rcFrame.bottom = rcFrame.top + 17; rcBorder.bottom = rcFrame.top + 17; COLORREF clrSelection = RGB( 0, 63, 63 ); COLORREF clrBorder = RGB( 100, 200, 255 ); HBRUSH brBorder = CreateSolidBrush( clrBorder ); HBRUSH brSelected = CreateHatchBrush( HS_FDIAGONAL, clrSelection ); for ( int i = 0; i < 2; i++ ) { FrameRect( dc, &rcFrame, brSelected ); InflateRect( &rcFrame, -1, -1 ); } FrameRect( dc, &rcBorder, brBorder ); FrameRect( dc, &rcFrame, brBorder ); DeleteObject( brSelected ); DeleteObject( brBorder ); rcClient.right -= 1; //rcClient.bottom += 1; InflateRect( &rcClient, -3, -1 ); } RECT rcEvent; rcEvent = rcClient; InflateRect( &rcEvent, 0, -deflateborder ); rcEvent.bottom = rcEvent.top + 10; if ( event->GetType() == CChoreoEvent::SPEAK && m_pWaveFile && !event->HasEndTime() ) { event->SetEndTime( event->GetStartTime() + m_pWaveFile->GetRunningLength() ); rcEvent.right = ( int )( m_pWaveFile->GetRunningLength() * m_pView->GetPixelsPerSecond() ); } if ( event->HasEndTime() ) { rcEvent.right = rcEvent.left + m_nDurationRightEdge; RECT rcEventLine = rcEvent; OffsetRect( &rcEventLine, 0, 1 ); if ( event->GetType() == CChoreoEvent::SPEAK ) { if ( m_pWaveFile ) { HBRUSH brEvent = CreateSolidBrush( COLOR_CHOREO_EVENT ); HBRUSH brBackground = CreateSolidBrush( COLOR_CHOREO_DARKBACKGROUND ); if ( !ramponly ) { FillRect( dc, &rcEventLine, brBackground ); } // Only draw wav form here if selected if ( IsSelected() ) { sound->RenderWavToDC( dc, rcEventLine, IsSelected() ? COLOR_CHOREO_EVENT_SELECTED : COLOR_CHOREO_EVENT, 0.0, m_pWaveFile->GetRunningLength(), m_pWaveFile ); } //FrameRect( dc, &rcEventLine, brEvent ); drawHelper.DrawColoredLine( COLOR_CHOREO_EVENT, PS_SOLID, 3, rcEventLine.left, rcEventLine.top, rcEventLine.left, rcEventLine.bottom ); drawHelper.DrawColoredLine( COLOR_CHOREO_EVENT, PS_SOLID, 3, rcEventLine.right, rcEventLine.top, rcEventLine.right, rcEventLine.bottom ); DeleteObject( brBackground ); DeleteObject( brEvent ); //rcEventLine.top -= 3; DrawRelativeTags( drawHelper, rcEventLine, m_pWaveFile->GetRunningLength(), event ); } } else { COLORREF clrEvent = IsSelected() ? COLOR_CHOREO_EVENT_SELECTED : COLOR_CHOREO_EVENT; if ( event->GetType() == CChoreoEvent::SUBSCENE ) { clrEvent = RGB( 200, 180, 200 ); } HBRUSH brEvent = CreateSolidBrush( clrEvent ); if ( !ramponly ) { FillRect( dc, &rcEventLine, brEvent ); } DeleteObject( brEvent ); if ( ramponly && IsSelected() ) { drawHelper.DrawOutlinedRect( RGB( 150, 180, 250 ), PS_SOLID, 1, rcEventLine ); } else { drawHelper.DrawColoredLine( RGB( 127, 127, 127 ), PS_SOLID, 1, rcEventLine.left, rcEventLine.bottom, rcEventLine.left, rcEventLine.top ); drawHelper.DrawColoredLine( RGB( 127, 127, 127 ), PS_SOLID, 1, rcEventLine.left, rcEventLine.top, rcEventLine.right, rcEventLine.top ); drawHelper.DrawColoredLine( RGB( 31, 31, 31 ), PS_SOLID, 1, rcEventLine.right, rcEventLine.top, rcEventLine.right, rcEventLine.bottom ); drawHelper.DrawColoredLine( RGB( 0, 0, 0 ), PS_SOLID, 1, rcEventLine.right, rcEventLine.bottom, rcEventLine.left, rcEventLine.bottom ); } g_pRampTool->DrawSamplesSimple( drawHelper, event, false, RGB( 63, 63, 63 ), rcEventLine ); DrawRelativeTags( drawHelper, rcEventLine, event->GetDuration(), event ); DrawAbsoluteTags( drawHelper, rcEventLine, event->GetDuration(), event ); } } else { RECT rcEventLine = rcEvent; OffsetRect( &rcEventLine, 0, 1 ); drawHelper.DrawColoredLine( COLOR_CHOREO_EVENT, PS_SOLID, 3, rcEventLine.left - 1, rcEventLine.top, rcEventLine.left - 1, rcEventLine.bottom ); } if ( event->IsUsingRelativeTag() ) { RECT rcTagName; rcTagName = rcClient; int length = drawHelper.CalcTextWidth( "Arial", 9, FW_NORMAL, event->GetRelativeTagName() ); rcTagName.right = rcTagName.left; rcTagName.left = rcTagName.right - length - 4; rcTagName.top += 3; rcTagName.bottom = rcTagName.top + 10; drawHelper.DrawColoredText( "Arial", 9, FW_NORMAL, RGB( 0, 100, 200 ), rcTagName, event->GetRelativeTagName() ); drawHelper.DrawFilledRect( RGB( 0, 100, 250 ), rcTagName.right-1, rcTagName.top-2, rcTagName.right+2, rcTagName.bottom + 2 ); } // Now draw the label RECT rcEventLabel; rcEventLabel = rcClient; InflateRect( &rcEventLabel, 0, -deflateborder ); rcEventLabel.top += 15; // rcEventLabel.bottom - 2 * ( fontsize + 2 ) - 1; rcEventLabel.bottom = rcEventLabel.top + fontsize + 2; rcEventLabel.left += 1; //rcEventLabel.left -= 8; int leftAdd = 16; if ( CChoreoEventWidget::GetImage( event->GetType() ) ) { mxbitmapdata_t *image = CChoreoEventWidget::GetImage( event->GetType() ); if ( image ) { DrawBitmapToDC( dc, rcEventLabel.left, rcEventLabel.top, leftAdd, leftAdd, *image ); } } if ( event->IsResumeCondition() ) { RECT rc = rcEventLabel; OffsetRect( &rc, leftAdd, 0 ); rc.right = rc.left + leftAdd; DrawBitmapToDC( dc, rc.left, rc.top, rc.right - rc.left, rc.bottom - rc.top, *CChoreoEventWidget::GetPauseImage() ); } //rcEventLabel.left += 8; OffsetRect( &rcEventLabel, 18, 1 ); int len = drawHelper.CalcTextWidth( "Arial", fontsize, FW_NORMAL, event->GetName() ); rcEventLabel.right = rcEventLabel.left + len + 2; drawHelper.DrawColoredText( "Arial", fontsize, FW_NORMAL, RGB( 0, 0, 120 ), rcEventLabel, event->GetName() ); }
void CheckForOverlappingFlexTracks( CChoreoScene *scene ) { for ( int a = 0; a < scene->GetNumActors(); ++a ) { CChoreoActor *actor = scene->GetActor( a ); CUtlRBTree< CChoreoEvent * > actorFlexEvents( 0, 0, ChoreEventStartTimeLessFunc ); for ( int c = 0; c < actor->GetNumChannels(); ++c ) { CChoreoChannel *channel = actor->GetChannel( c ); for ( int e = 0 ; e < channel->GetNumEvents(); ++e ) { CChoreoEvent *event = channel->GetEvent( e ); if ( event->GetType() != CChoreoEvent::FLEXANIMATION ) continue; actorFlexEvents.Insert( event ); } } CUtlVector< CUtlLinkedList< CChoreoEvent*, int > > rows; bool done = false; int i; // Now check for overlaps for ( i = actorFlexEvents.FirstInorder(); i != actorFlexEvents.InvalidIndex() && !done; i = actorFlexEvents.NextInorder( i ) ) { CChoreoEvent *e = actorFlexEvents[ i ]; if ( !rows.Count() ) { rows.AddToTail(); CUtlLinkedList< CChoreoEvent*, int >& list = rows[ 0 ]; list.AddToHead( e ); continue; } // Does it come totally after what's in rows[0]? int rowCount = rows.Count(); bool addrow = true; for ( int j = 0; j < rowCount; j++ ) { CUtlLinkedList< CChoreoEvent*, int >& list = rows[ j ]; char offender[ 256 ]; if ( !EventCollidesWithRows( list, e, offender, sizeof( offender ) ) ) { // Update row event list list.AddToHead( e ); addrow = false; break; } else { Msg( "[%s] has overlapping events for actor [%s] [%s] [flex: %s]\n", scene->GetFilename(), actor->GetName(), e->GetName(), offender ); done = true; } } if ( addrow ) { // Add a new row int idx = rows.AddToTail(); CUtlLinkedList< CChoreoEvent *, int >& list = rows[ idx ]; list.AddToHead( e ); } } // Assert( rows.Count() <= 1 ); } }