1 /* === S Y N F I G ========================================================= */
3 ** \brief bsd_mpeg1 Target Module
6 ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
8 ** This package is free software; you can redistribute it and/or
9 ** modify it under the terms of the GNU General Public License as
10 ** published by the Free Software Foundation; either version 2 of
11 ** the License, or (at your option) any later version.
13 ** This package is distributed in the hope that it will be useful,
14 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
15 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 ** General Public License for more details.
19 ** === N O T E S ===========================================================
21 ** ========================================================================= */
23 /* === H E A D E R S ======================================================= */
34 #include <ETL/stringf>
42 /* === M A C R O S ========================================================= */
44 using namespace synfig;
48 /* === G L O B A L S ======================================================= */
50 const char bsd_mpeg1::Name[]="mpeg1";
51 const char bsd_mpeg1::Ext[]="mpg";
53 #define tmp_dir string("/tmp/")
55 /* === M E T H O D S ======================================================= */
58 bsd_mpeg1::New(const char *filename)
60 return new bsd_mpeg1(filename);
63 bsd_mpeg1::bsd_mpeg1(const char *Filename)
66 passthru=ppm::New((tmp_dir+"temp.ppm").c_str());
71 bsd_mpeg1::~bsd_mpeg1()
76 cerr<<"Encoding "<<filename<<"with \"mpeg_encode\" utility..."<<endl;
77 if(system("mpeg_encode -float-dct -realquiet /tmp/temp.param")!=0)
79 cerr<<"Failed to encode "<<filename<<"with \"mpeg_encode\" utility"<<endl;
80 cerr<<"Are you sure it is installed?"<<endl;
85 bsd_mpeg1::set_rend_desc(RendDesc *given_desc)
91 paramfile=fopen((tmp_dir+"temp.param").c_str(),"wt");
92 int bitrate=150; // kbytes per second
93 int buffer_drift=50; // bitrate drift (in kbytes per second)
99 "PATTERN IBBPBBPBBPBBPBBP\n"
101 "BASE_FILE_FORMAT PPM\n"
104 "SLICES_PER_FRAME 1\n"
108 "PSEARCH_ALG LOGARITHMIC\n"
109 "BSEARCH_ALG CROSS2\n"
116 "REFERENCE_FRAME ORIGINAL\n"
118 // "BIT_RATE 1000000\n"
119 // "BUFFER_SIZE 327680\n"
121 ,filename.c_str(),bitrate,buffer_drift);
122 float fps=given_desc->get_frame_rate();
125 // 23.976, 24, 25, 29.97, 30, 50 ,59.94, 60
129 fprintf(paramfile,"FRAME_RATE 23.976\n");
130 given_desc->set_frame_rate(23.976);
132 if(fps>=24.0 && fps <25.0)
134 fprintf(paramfile,"FRAME_RATE 24\n");
135 given_desc->set_frame_rate(24);
137 if(fps>=25.0 && fps <29.97)
139 fprintf(paramfile,"FRAME_RATE 25\n");
140 given_desc->set_frame_rate(25);
142 if(fps>=29.97 && fps <30.0)
144 fprintf(paramfile,"FRAME_RATE 29.97\n");
145 given_desc->set_frame_rate(29.97);
147 if(fps>=29.97 && fps <30.0)
149 fprintf(paramfile,"FRAME_RATE 29.97\n");
150 given_desc->set_frame_rate(29.97);
152 if(fps>=30.0 && fps <50.0)
154 fprintf(paramfile,"FRAME_RATE 30\n");
155 given_desc->set_frame_rate(30.0);
157 if(fps>=50.0 && fps <59.94)
159 fprintf(paramfile,"FRAME_RATE 50\n");
160 given_desc->set_frame_rate(50);
164 fprintf(paramfile,"FRAME_RATE 59.94\n");
165 given_desc->set_frame_rate(59.94);
168 // Make sure that the width and height
169 // are multiples of 8
170 given_desc->set_w((given_desc->get_w()+4)/8*8);
171 given_desc->set_h((given_desc->get_h()+4)/8*8);
173 if(!passthru->set_rend_desc(given_desc))
180 "tmp/temp*.ppm [%04d-%04d]\n"
181 "END_INPUT\n",desc.get_frame_start(),desc.get_frame_end()-1);
190 bsd_mpeg1::end_frame()
192 passthru->end_frame();
196 bsd_mpeg1::start_frame(synfig::ProgressCallback *callback)
198 return passthru->start_frame(callback);
202 bsd_mpeg1::start_scanline(int scanline)
204 return passthru->start_scanline(scanline);
208 bsd_mpeg1::end_scanline(void)
210 return passthru->end_scanline();