port some of small fixes from trunk; disable autohold while playing a movie (r2624), fix movie length (r2629), keyrepeat improvement (r2641-2643)
This commit is contained in:
parent
3263ba4ef0
commit
624c72fd49
|
@ -2561,6 +2561,7 @@ void NDS_setPad(bool R,bool L,bool D,bool U,bool T,bool S,bool B,bool A,bool Y,b
|
|||
W=padarray[10];
|
||||
E=padarray[11];
|
||||
|
||||
if (movieMode != MOVIEMODE_PLAY) {
|
||||
if(AutoHold.Right) R=!padarray[0];
|
||||
if(AutoHold.Left) L=!padarray[1];
|
||||
if(AutoHold.Down) D=!padarray[2];
|
||||
|
@ -2573,6 +2574,7 @@ void NDS_setPad(bool R,bool L,bool D,bool U,bool T,bool S,bool B,bool A,bool Y,b
|
|||
if(AutoHold.X) X=!padarray[9];
|
||||
if(AutoHold.L) W=!padarray[10];
|
||||
if(AutoHold.R) E=!padarray[11];
|
||||
}
|
||||
|
||||
//this macro is the opposite of what you would expect
|
||||
#define FIX(b) (b?0:0x80)
|
||||
|
|
|
@ -416,7 +416,7 @@ LRESULT CALLBACK WifiSettingsDlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM
|
|||
// const char *cflash_disk_image_file;
|
||||
//};
|
||||
|
||||
int KeyInDelayInCount=10;
|
||||
int KeyInDelayInCount=30;
|
||||
|
||||
static int lastTime = timeGetTime();
|
||||
int repeattime;
|
||||
|
@ -456,20 +456,30 @@ VOID CALLBACK KeyInputTimer( UINT idEvent, UINT uMsg, DWORD_PTR dwUser, DWORD_PT
|
|||
// if((!GUI.InactivePause || !Settings.ForcedPause)
|
||||
// || (GUI.BackgroundInput || !(Settings.ForcedPause & (PAUSE_INACTIVE_WINDOW | PAUSE_WINDOW_ICONISED))))
|
||||
// {
|
||||
static uint32 joyState [256];
|
||||
for(int i = 0 ; i < 255 ; i++)
|
||||
static u32 joyState [256];
|
||||
static bool initialized = false;
|
||||
if(!initialized) {
|
||||
memset(joyState,0,sizeof(joyState));
|
||||
initialized = true;
|
||||
}
|
||||
for(int i = 0 ; i < 256 ; i++)
|
||||
{
|
||||
bool active = !S9xGetState(i);
|
||||
if(active)
|
||||
{
|
||||
if(joyState[i] < ULONG_MAX) // 0xffffffffUL
|
||||
joyState[i]++;
|
||||
if(joyState[i] == 1 || joyState[i] >= (unsigned) KeyInDelayInCount) {
|
||||
if(joyState[i] == 1 || joyState[i] == (unsigned) KeyInDelayInCount) {
|
||||
|
||||
|
||||
//HEY HEY HEY! this only repeats once. this is what it needs to be like for frame advance.
|
||||
//if anyone wants a different kind of repeat, then the whole setup will need to be redone
|
||||
|
||||
//sort of fix the auto repeating
|
||||
//TODO find something better
|
||||
// repeattime++;
|
||||
// if(repeattime % 10 == 0) {
|
||||
|
||||
//printf("trigger %d\n",i);
|
||||
PostMessage(MainWindow->getHWnd(), WM_CUSTKEYDOWN, (WPARAM)(i),(LPARAM)(NULL));
|
||||
repeattime=0;
|
||||
// }
|
||||
|
@ -1210,7 +1220,6 @@ DWORD WINAPI run()
|
|||
}
|
||||
|
||||
if(FastForward) {
|
||||
|
||||
if(framesskipped < 9)
|
||||
{
|
||||
skipnextframe = 1;
|
||||
|
@ -1967,6 +1976,7 @@ int WINAPI WinMain (HINSTANCE hThisInstance,
|
|||
int nFunsterStil)
|
||||
|
||||
{
|
||||
timeBeginPeriod(1);
|
||||
hAppInst=hThisInstance;
|
||||
OpenConsole(); // Init debug console
|
||||
|
||||
|
@ -2524,18 +2534,25 @@ void FrameAdvance(bool state)
|
|||
{
|
||||
if(state) {
|
||||
if(first) {
|
||||
execute = TRUE;
|
||||
frameAdvance=true;
|
||||
first=false;
|
||||
}
|
||||
else {
|
||||
execute = TRUE;
|
||||
first=false;
|
||||
}
|
||||
}
|
||||
else {
|
||||
first = true;
|
||||
if(frameAdvance)
|
||||
{}
|
||||
else
|
||||
{
|
||||
emu_halt();
|
||||
SPU_Pause(1);
|
||||
emu_paused = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
enum CONFIGSCREEN
|
||||
|
|
|
@ -36,13 +36,12 @@ void Describe(HWND hwndDlg)
|
|||
|
||||
u32 num_frames = md.records.size();
|
||||
|
||||
u32 div = 60;
|
||||
float tempCount = (num_frames % 60); //Get fraction of a second
|
||||
float getTime = ((tempCount / div) * 100); //Convert to 2 digit number
|
||||
int fraction = getTime; //Convert to 2 digit int
|
||||
int seconds = (num_frames / div) % 60;
|
||||
int minutes = (num_frames/(div*60))%60;
|
||||
int hours = num_frames/(div*60*60);
|
||||
double tempCount = num_frames / (33513982.0/6/355/263);
|
||||
int num_seconds = tempCount;
|
||||
int fraction = (tempCount - num_seconds) * 100;
|
||||
int seconds = num_seconds % 60;
|
||||
int minutes = (num_seconds / 60) % 60;
|
||||
int hours = (num_seconds / 60 / 60) % 60;
|
||||
char tmp[256];
|
||||
sprintf(tmp, "%02d:%02d:%02d.%02d", hours, minutes, seconds, fraction);
|
||||
|
||||
|
|
Loading…
Reference in New Issue