40     for (y = 0; y < 
height; y++)
 
   41         for (x = 0; x < 
width; x++)
 
   42             data[0][y * linesize[0] + x] = x + y + frame_index * 3;
 
   45     for (y = 0; y < 
height / 2; y++) {
 
   46         for (x = 0; x < 
width / 2; x++) {
 
   47             data[1][y * linesize[1] + x] = 128 + y + frame_index * 2;
 
   48             data[2][y * linesize[2] + x] = 64 + x + frame_index * 5;
 
   53 int main(
int argc, 
char **argv)
 
   55     uint8_t *src_data[4], *dst_data[4];
 
   56     int src_linesize[4], dst_linesize[4];
 
   57     int src_w = 320, src_h = 240, dst_w, dst_h;
 
   59     const char *dst_size = 
NULL;
 
   60     const char *dst_filename = 
NULL;
 
   67         fprintf(stderr, 
"Usage: %s output_file output_size\n" 
   68                 "API example program to show how to scale an image with libswscale.\n" 
   69                 "This program generates a series of pictures, rescales them to the given " 
   70                 "output_size and saves them to an output file named output_file\n." 
   74     dst_filename = argv[1];
 
   79                 "Invalid size '%s', must be in the form WxH or a valid size abbreviation\n",
 
   84     dst_file = fopen(dst_filename, 
"wb");
 
   86         fprintf(stderr, 
"Could not open destination file %s\n", dst_filename);
 
   92                              dst_w, dst_h, dst_pix_fmt,
 
   96                 "Impossible to create scale context for the conversion " 
   97                 "fmt:%s s:%dx%d -> fmt:%s s:%dx%d\n",
 
  106                               src_w, src_h, src_pix_fmt, 16)) < 0) {
 
  107         fprintf(stderr, 
"Could not allocate source image\n");
 
  113                               dst_w, dst_h, dst_pix_fmt, 1)) < 0) {
 
  114         fprintf(stderr, 
"Could not allocate destination image\n");
 
  119     for (
i = 0; 
i < 100; 
i++) {
 
  124         sws_scale(sws_ctx, (
const uint8_t * 
const*)src_data,
 
  125                   src_linesize, 0, src_h, dst_data, dst_linesize);
 
  128         fwrite(dst_data[0], 1, dst_bufsize, dst_file);
 
  131     fprintf(stderr, 
"Scaling succeeded. Play the output file with the command:\n" 
  132            "ffplay -f rawvideo -pix_fmt %s -video_size %dx%d %s\n",