mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-24 23:11:14 +01:00
Merge pull request #3444 from RisingFog/avidumpfixes
AVIDump Clean Up and Fixes
This commit is contained in:
commit
0da8bd0f61
@ -13,6 +13,7 @@
|
|||||||
#include "Common/StringUtil.h"
|
#include "Common/StringUtil.h"
|
||||||
#include "Common/Logging/Log.h"
|
#include "Common/Logging/Log.h"
|
||||||
|
|
||||||
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/CoreTiming.h"
|
#include "Core/CoreTiming.h"
|
||||||
#include "Core/HW/SystemTimers.h"
|
#include "Core/HW/SystemTimers.h"
|
||||||
#include "Core/HW/VideoInterface.h" //for TargetRefreshRate
|
#include "Core/HW/VideoInterface.h" //for TargetRefreshRate
|
||||||
@ -28,9 +29,6 @@
|
|||||||
#include <vfw.h>
|
#include <vfw.h>
|
||||||
#include <winerror.h>
|
#include <winerror.h>
|
||||||
|
|
||||||
#include "Core/ConfigManager.h" // for PAL60
|
|
||||||
#include "Core/CoreTiming.h"
|
|
||||||
|
|
||||||
static HWND s_emu_wnd;
|
static HWND s_emu_wnd;
|
||||||
static LONG s_byte_buffer;
|
static LONG s_byte_buffer;
|
||||||
static LONG s_frame_count;
|
static LONG s_frame_count;
|
||||||
@ -42,7 +40,6 @@ static int s_file_count;
|
|||||||
static u64 s_last_frame;
|
static u64 s_last_frame;
|
||||||
static PAVISTREAM s_stream;
|
static PAVISTREAM s_stream;
|
||||||
static PAVISTREAM s_stream_compressed;
|
static PAVISTREAM s_stream_compressed;
|
||||||
static int s_frame_rate;
|
|
||||||
static AVISTREAMINFO s_header;
|
static AVISTREAMINFO s_header;
|
||||||
static AVICOMPRESSOPTIONS s_options;
|
static AVICOMPRESSOPTIONS s_options;
|
||||||
static AVICOMPRESSOPTIONS* s_array_options[1];
|
static AVICOMPRESSOPTIONS* s_array_options[1];
|
||||||
@ -63,11 +60,6 @@ bool AVIDump::Start(HWND hWnd, int w, int h)
|
|||||||
|
|
||||||
s_last_frame = CoreTiming::GetTicks();
|
s_last_frame = CoreTiming::GetTicks();
|
||||||
|
|
||||||
if (SConfig::GetInstance().m_SYSCONF->GetData<u8>("IPL.E60"))
|
|
||||||
s_frame_rate = 60; // always 60, for either pal60 or ntsc
|
|
||||||
else
|
|
||||||
s_frame_rate = VideoInterface::TargetRefreshRate; // 50 or 60, depending on region
|
|
||||||
|
|
||||||
// clear CFR frame cache on start, not on file create (which is also segment switch)
|
// clear CFR frame cache on start, not on file create (which is also segment switch)
|
||||||
SetBitmapFormat();
|
SetBitmapFormat();
|
||||||
StoreFrame(nullptr);
|
StoreFrame(nullptr);
|
||||||
@ -93,6 +85,11 @@ bool AVIDump::CreateFile()
|
|||||||
{
|
{
|
||||||
File::Delete(movie_file_name);
|
File::Delete(movie_file_name);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Stop and cancel dumping the video
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AVIFileInit();
|
AVIFileInit();
|
||||||
@ -311,7 +308,7 @@ bool AVIDump::SetVideoFormat()
|
|||||||
memset(&s_header, 0, sizeof(s_header));
|
memset(&s_header, 0, sizeof(s_header));
|
||||||
s_header.fccType = streamtypeVIDEO;
|
s_header.fccType = streamtypeVIDEO;
|
||||||
s_header.dwScale = 1;
|
s_header.dwScale = 1;
|
||||||
s_header.dwRate = s_frame_rate;
|
s_header.dwRate = VideoInterface::TargetRefreshRate;
|
||||||
s_header.dwSuggestedBufferSize = s_bitmap.biSizeImage;
|
s_header.dwSuggestedBufferSize = s_bitmap.biSizeImage;
|
||||||
|
|
||||||
return SUCCEEDED(AVIFileCreateStream(s_file, &s_stream, &s_header));
|
return SUCCEEDED(AVIFileCreateStream(s_file, &s_stream, &s_header));
|
||||||
@ -383,6 +380,21 @@ bool AVIDump::CreateFile()
|
|||||||
(File::GetUserPath(D_DUMPFRAMES_IDX) + "framedump0.avi").c_str());
|
(File::GetUserPath(D_DUMPFRAMES_IDX) + "framedump0.avi").c_str());
|
||||||
File::CreateFullPath(s_format_context->filename);
|
File::CreateFullPath(s_format_context->filename);
|
||||||
|
|
||||||
|
// Ask to delete file
|
||||||
|
if (File::Exists(s_format_context->filename))
|
||||||
|
{
|
||||||
|
if (SConfig::GetInstance().m_DumpFramesSilent ||
|
||||||
|
AskYesNoT("Delete the existing file '%s'?", s_format_context->filename))
|
||||||
|
{
|
||||||
|
File::Delete(s_format_context->filename);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Stop and cancel dumping the video
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!(s_format_context->oformat = av_guess_format("avi", nullptr, nullptr)) ||
|
if (!(s_format_context->oformat = av_guess_format("avi", nullptr, nullptr)) ||
|
||||||
!(s_stream = avformat_new_stream(s_format_context, codec)))
|
!(s_stream = avformat_new_stream(s_format_context, codec)))
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user