converted more mixed tab/space indentations to tabs. only whitespace changes.
[blender.git] / source / blender / blenkernel / intern / writeavi.c
index f84bd69..ba7f9bd 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/*
  * Functions for writing avi-format files.
  * Added interface for generic movie support (ton)
  *
@@ -18,7 +18,7 @@
  *
  * 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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  *
  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
  * All rights reserved.
  * 
  */
 
+/** \file blender/blenkernel/intern/writeavi.c
+ *  \ingroup bke
+ */
+
+
 #include <string.h>
 
 #include "MEM_guardedalloc.h"
 #include "DNA_scene_types.h"
 
 #include "BLI_blenlib.h"
+#include "BLI_utildefines.h"
 
 #include "BKE_global.h"
+#include "BKE_main.h"
+#include "BKE_report.h"
+
 #include "BKE_writeavi.h"
 #include "AVI_avi.h"
 
+/* callbacks */
+static int start_avi(Scene *scene, RenderData *rd, int rectx, int recty, ReportList *reports);
+static void end_avi(void);
+static int append_avi(RenderData *rd, int frame, int *pixels, int rectx, int recty, ReportList *reports);
+static void filepath_avi(char *string, RenderData *rd);
 
 /* ********************** general blender movie support ***************************** */
 
@@ -65,13 +79,9 @@ bMovieHandle *BKE_get_movie_handle(int imtype)
        mh.append_movie= append_avi;
        mh.end_movie= end_avi;
        mh.get_next_frame = NULL;
+       mh.get_movie_path = filepath_avi;
        
        /* do the platform specific handles */
-#ifdef __sgi
-       if (imtype == R_MOVIE) {
-               
-       }
-#endif
 #if defined(_WIN32) && !defined(FREE_WINDOWS)
        if (imtype == R_AVICODEC) {             
                //XXX mh.start_movie= start_avi_codec;
@@ -84,13 +94,15 @@ bMovieHandle *BKE_get_movie_handle(int imtype)
                mh.start_movie= start_qt;
                mh.append_movie= append_qt;
                mh.end_movie= end_qt;
+               mh.get_movie_path = filepath_qt;
        }
 #endif
 #ifdef WITH_FFMPEG
-       if (imtype == R_FFMPEG) {
+       if (ELEM4(imtype, R_FFMPEG, R_H264, R_XVID, R_THEORA)) {
                mh.start_movie = start_ffmpeg;
                mh.append_movie = append_ffmpeg;
                mh.end_movie = end_ffmpeg;
+               mh.get_movie_path = filepath_ffmpeg;
        }
 #endif
        if (imtype == R_FRAMESERVER) {
@@ -109,24 +121,22 @@ bMovieHandle *BKE_get_movie_handle(int imtype)
 static AviMovie *avi=NULL;
 static int sframe;
 
-void makeavistring (RenderData *rd, char *string) 
+static void filepath_avi (char *string, RenderData *rd)
 {
-       char txt[64];
-
-       if (string==0) return;
+       if (string==NULL) return;
 
        strcpy(string, rd->pic);
-       BLI_convertstringcode(string, G.sce);
+       BLI_path_abs(string, G.main->name);
 
        BLI_make_existing_file(string);
 
-       if (BLI_strcasecmp(string + strlen(string) - 4, ".avi")) {
-               sprintf(txt, "%04d_%04d.avi", (rd->sfra) , (rd->efra) );
-               strcat(string, txt);
+       if (!BLI_testextensie(string, ".avi")) {
+               BLI_path_frame_range(string, rd->sfra, rd->efra, 4);
+               strcat(string, ".avi");
        }
 }
 
-void start_avi(RenderData *rd, int rectx, int recty)
+static int start_avi(Scene *scene, RenderData *rd, int rectx, int recty, ReportList *reports)
 {
        int x, y;
        char name[256];
@@ -134,7 +144,9 @@ void start_avi(RenderData *rd, int rectx, int recty)
        int quality;
        double framerate;
        
-       makeavistring(rd, name);
+       (void)scene; /* unused */
+       
+       filepath_avi(name, rd);
 
        sframe = (rd->sfra);
        x = rectx;
@@ -146,16 +158,16 @@ void start_avi(RenderData *rd, int rectx, int recty)
        avi = MEM_mallocN (sizeof(AviMovie), "avimovie");
 
        /* RPW 11-21-2002 
-        if (rd->imtype != AVI_FORMAT_MJPEG) format = AVI_FORMAT_AVI_RGB;
+       if (rd->imtype != AVI_FORMAT_MJPEG) format = AVI_FORMAT_AVI_RGB;
        */
        if (rd->imtype != R_AVIJPEG ) format = AVI_FORMAT_AVI_RGB;
        else format = AVI_FORMAT_MJPEG;
 
        if (AVI_open_compress (name, avi, 1, format) != AVI_ERROR_NONE) {
-               printf("cannot open or start AVI movie file");
+               BKE_report(reports, RPT_ERROR, "Cannot open or start AVI movie file.");
                MEM_freeN (avi);
                avi = NULL;
-               return;
+               return 0;
        }
                        
        AVI_set_compress_option (avi, AVI_OPTION_TYPE_MAIN, 0, AVI_OPTION_WIDTH, &x);
@@ -169,18 +181,17 @@ void start_avi(RenderData *rd, int rectx, int recty)
 /*     avi->odd_fields= (rd->mode & R_ODDFIELD)?1:0; */
        
        printf("Created avi: %s\n", name);
+       return 1;
 }
 
-void append_avi(RenderData *rd, int frame, int *pixels, int rectx, int recty)
+static int append_avi(RenderData *UNUSED(rd), int frame, int *pixels, int rectx, int recty, ReportList *UNUSED(reports))
 {
        unsigned int *rt1, *rt2, *rectot;
        int x, y;
        char *cp, rt;
        
-       if (avi == NULL) {
-               G.afbreek = 1;
-               return;
-       }
+       if (avi == NULL)
+               return 0;
 
        /* note that libavi free's the buffer... stupid interface - zr */
        rectot= MEM_mallocN(rectx*recty*sizeof(int), "rectot");
@@ -204,9 +215,11 @@ void append_avi(RenderData *rd, int frame, int *pixels, int rectx, int recty)
        
        AVI_write_frame (avi, (frame-sframe), AVI_FORMAT_RGB32, rectot, rectx*recty*4);
 //     printf ("added frame %3d (frame %3d in avi): ", frame, frame-sframe);
+
+       return 1;
 }
 
-void end_avi(void)
+static void end_avi(void)
 {
        if (avi == NULL) return;
 
@@ -214,3 +227,13 @@ void end_avi(void)
        MEM_freeN (avi);
        avi= NULL;
 }
+
+/* similar to BKE_makepicstring() */
+void BKE_makeanimstring(char *string, RenderData *rd)
+{
+       bMovieHandle *mh= BKE_get_movie_handle(rd->imtype);
+       if(mh->get_movie_path)
+               mh->get_movie_path(string, rd);
+       else
+               string[0]= '\0';
+}