RetroArch/record/ffemu.h

95 lines
2.1 KiB
C
Raw Normal View History

2012-04-21 23:13:50 +02:00
/* RetroArch - A frontend for libretro.
2012-01-08 01:08:18 +01:00
* Copyright (C) 2010-2012 - Hans-Kristian Arntzen
2011-12-24 13:46:12 +01:00
*
2012-04-21 23:13:50 +02:00
* RetroArch is free software: you can redistribute it and/or modify it under the terms
2011-12-24 13:46:12 +01:00
* of the GNU General Public License as published by the Free Software Found-
* ation, either version 3 of the License, or (at your option) any later version.
*
2012-04-21 23:13:50 +02:00
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
2011-12-24 13:46:12 +01:00
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
2012-04-21 23:31:57 +02:00
* You should have received a copy of the GNU General Public License along with RetroArch.
2011-12-24 13:46:12 +01:00
* If not, see <http://www.gnu.org/licenses/>.
*/
2011-01-03 17:51:17 +01:00
#ifndef __FFEMU_H
#define __FFEMU_H
#include <stdint.h>
#include <stddef.h>
#ifdef __cplusplus
extern "C" {
#endif
2012-08-25 22:38:49 +02:00
enum ffemu_pix_format
{
FFEMU_PIX_RGB565 = 0,
2012-08-25 22:38:49 +02:00
FFEMU_PIX_BGR24,
FFEMU_PIX_ARGB8888
};
2011-01-03 17:51:17 +01:00
// Parameters passed to ffemu_new()
struct ffemu_params
{
// FPS of input video.
double fps;
// Sample rate of input audio.
double samplerate;
2011-01-03 17:51:17 +01:00
// Desired output resolution.
unsigned out_width;
unsigned out_height;
2011-06-14 22:44:54 +02:00
// Total size of framebuffer used in input.
unsigned fb_width;
unsigned fb_height;
2011-01-03 17:51:17 +01:00
// Aspect ratio of input video. Parameters are passed to the muxer,
// the video itself is not scaled.
float aspect_ratio;
2011-01-03 17:51:17 +01:00
// Audio channels.
unsigned channels;
// Input pixel format.
2012-08-25 22:38:49 +02:00
enum ffemu_pix_format pix_fmt;
2011-08-11 05:25:31 +02:00
2011-01-04 15:44:05 +01:00
// Filename to dump to.
const char *filename;
// Path to config. Optional.
const char *config;
2011-01-03 17:51:17 +01:00
};
struct ffemu_video_data
{
const void *data;
unsigned width;
unsigned height;
2012-08-25 22:38:49 +02:00
int pitch;
2011-11-22 17:27:02 +01:00
bool is_dupe;
2011-01-03 17:51:17 +01:00
};
struct ffemu_audio_data
{
const int16_t *data;
size_t frames;
};
typedef struct ffemu ffemu_t;
ffemu_t *ffemu_new(const struct ffemu_params *params);
void ffemu_free(ffemu_t* handle);
bool ffemu_push_video(ffemu_t *handle, const struct ffemu_video_data *data);
bool ffemu_push_audio(ffemu_t *handle, const struct ffemu_audio_data *data);
bool ffemu_finalize(ffemu_t *handle);
2011-01-03 17:51:17 +01:00
#ifdef __cplusplus
}
#endif
#endif