MainWorkflow.cpp 4.36 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
/*****************************************************************************
 * MainWorkflow.cpp : Will query all of the track workflows to render the final
 *                    image
 *****************************************************************************
 * Copyright (C) 2008-2009 the VLMC team
 *
 * Authors: Hugo Beauzee-Luyssen <hugo@vlmc.org>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
 *****************************************************************************/

#include <QtDebug>

#include "MainWorkflow.h"

28 29 30 31 32
unsigned char*  MainWorkflow::blackOutput = NULL;

MainWorkflow::MainWorkflow( int trackCount ) :
        m_trackCount( trackCount ),
        m_renderStarted( false )
33
{
34
    if ( MainWorkflow::blackOutput == NULL )
35
    {
36 37 38 39 40 41 42 43 44 45
        //TODO: this ain't free !
        MainWorkflow::blackOutput = new unsigned char[VIDEOHEIGHT * VIDEOWIDTH * 3];
        memset( MainWorkflow::blackOutput, 0, VIDEOHEIGHT * VIDEOWIDTH * 3 );
    }

    m_tracks = new Toggleable<TrackWorkflow*>[trackCount];
    for (int i = 0; i < trackCount; ++i)
    {
        m_tracks[i].setPtr( new TrackWorkflow( i ) );
        connect( m_tracks[i], SIGNAL( trackEndReached( unsigned int ) ), this, SLOT( trackEndReached(unsigned int) ) );
46
    }
47 48
}

49
void    MainWorkflow::addClip( Clip* clip, unsigned int trackId, qint64 start )
50
{
51
    Q_ASSERT_X( trackId < m_trackCount, "MainWorkflow::addClip",
52 53
                "The specified trackId isn't valid, for it's higher than the number of tracks");

54
//    qDebug() << "MainWorkflow: Adding clip" << clip->getUuid() << "to track" << trackId;
55 56 57
    //if the track is deactivated, we need to reactivate it :
    if ( m_tracks[trackId].deactivated() == true )
        m_tracks[trackId].activate();
58
    m_tracks[trackId]->addClip( clip, start );
59 60
    if ( m_tracks[trackId]->getLength() > m_length )
        m_length = m_tracks[trackId]->getLength();
61
}
62 63 64

void    MainWorkflow::startRender()
{
65 66
    qint64      maxLength = 0;

67
    m_renderStarted = true;
68 69
    m_currentFrame = 0;
    emit frameChanged( 0 );
70 71 72 73 74 75
    for ( unsigned int i = 0; i < m_trackCount; ++i )
    {
        if ( m_tracks[i]->getLength() > maxLength )
            maxLength = m_tracks[i]->getLength();
    }
    m_length = maxLength;
76 77 78 79
}

unsigned char*    MainWorkflow::getOutput()
{
80 81 82 83 84 85 86 87 88 89 90 91 92 93
    unsigned char* ret;

    for ( unsigned int i = 0; i < m_trackCount; ++i )
    {
        if ( m_tracks[i].activated() == false )
            continue ;
        if ( ( ret = m_tracks[i]->getOutput( m_currentFrame ) ) != NULL )
        {
            break ;
        }
    }
    if ( ret == NULL )
        ret = MainWorkflow::blackOutput;

94 95
    ++m_currentFrame;
    emit frameChanged( m_currentFrame );
96
    emit positionChanged( (float)m_currentFrame / (float)m_length );
97
    return ret;
98
}
99 100 101

void        MainWorkflow::setPosition( float pos )
{
102 103 104 105 106
    //Since any track can be reactivated, we reactivate all of them, and let them
    //unable themself if required.
    for ( unsigned int i = 0; i < m_trackCount; ++i)
        m_tracks[i].activate();

107 108
    if ( m_renderStarted == false )
        return ;
109 110 111
    qint64  frame = (float)m_length * pos;
    m_currentFrame = frame;
    emit frameChanged( frame );
112
    //Do not emit a signal for the RenderWidget, since it's the one that triggered that call...
113 114 115 116 117 118
}

qint64      MainWorkflow::getLength() const
{
    return m_length;
}
119

120
void        MainWorkflow::trackEndReached( unsigned int trackId )
121
{
122 123 124 125 126 127 128
    m_tracks[trackId].deactivate();

    for ( unsigned int i = 0; i < m_trackCount; ++i)
    {
        if ( m_tracks[i].activated() == true )
            return ;
    }
129
    emit mainWorkflowEndReached();
130 131 132
    m_renderStarted = false;
    m_currentFrame = 0;
    emit frameChanged( 0 );
133
}
134 135 136 137 138

unsigned int    MainWorkflow::getTrackCount() const
{
    return m_trackCount;
}