mirror of
https://github.com/reactos/reactos.git
synced 2025-01-03 21:09:19 +00:00
[MPLAY32] Don't use the timer proc to check if playback should stop. Fixes an issue where the playback does not stop/repeat with some devices if it has reached its end. By Ricardo Hanke. CORE-9414
svn path=/trunk/; revision=67762
This commit is contained in:
parent
f7719d6aff
commit
871a52055d
1 changed files with 18 additions and 22 deletions
|
@ -648,7 +648,7 @@ StopPlayback(HWND hwnd)
|
||||||
SendMessage(hTrackBar, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)1);
|
SendMessage(hTrackBar, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)1);
|
||||||
|
|
||||||
mciGeneric.dwCallback = (DWORD_PTR)hwnd;
|
mciGeneric.dwCallback = (DWORD_PTR)hwnd;
|
||||||
mciError = mciSendCommand(wDeviceId, MCI_STOP, MCI_NOTIFY, (DWORD_PTR)&mciGeneric);
|
mciError = mciSendCommand(wDeviceId, MCI_STOP, MCI_WAIT, (DWORD_PTR)&mciGeneric);
|
||||||
if (mciError != 0)
|
if (mciError != 0)
|
||||||
{
|
{
|
||||||
ShowMCIError(hwnd, mciError);
|
ShowMCIError(hwnd, mciError);
|
||||||
|
@ -744,7 +744,6 @@ VOID CALLBACK
|
||||||
PlayTimerProc(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime)
|
PlayTimerProc(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime)
|
||||||
{
|
{
|
||||||
MCI_STATUS_PARMS mciStatus;
|
MCI_STATUS_PARMS mciStatus;
|
||||||
MCI_PLAY_PARMS mciPlay;
|
|
||||||
DWORD dwPos;
|
DWORD dwPos;
|
||||||
|
|
||||||
if (wDeviceId == 0) KillTimer(hwnd, IDT_PLAYTIMER);
|
if (wDeviceId == 0) KillTimer(hwnd, IDT_PLAYTIMER);
|
||||||
|
@ -753,24 +752,8 @@ PlayTimerProc(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime)
|
||||||
mciSendCommand(wDeviceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD_PTR)&mciStatus);
|
mciSendCommand(wDeviceId, MCI_STATUS, MCI_STATUS_ITEM, (DWORD_PTR)&mciStatus);
|
||||||
dwPos = mciStatus.dwReturn;
|
dwPos = mciStatus.dwReturn;
|
||||||
|
|
||||||
if ((UINT)dwPos >= MaxFilePos)
|
SendMessage(hTrackBar, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)dwPos);
|
||||||
{
|
UpdateTimeDisplay(hTimeDisplay);
|
||||||
if (!bRepeat)
|
|
||||||
{
|
|
||||||
StopPlayback(hwnd);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
mciSendCommand(wDeviceId, MCI_SEEK, MCI_WAIT | MCI_SEEK_TO_START, 0);
|
|
||||||
mciPlay.dwCallback = (DWORD_PTR)hwnd;
|
|
||||||
mciSendCommand(wDeviceId, MCI_PLAY, MCI_NOTIFY, (DWORD_PTR)&mciPlay);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SendMessage(hTrackBar, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)dwPos);
|
|
||||||
UpdateTimeDisplay(hTimeDisplay);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static VOID
|
static VOID
|
||||||
|
@ -829,7 +812,7 @@ TogglePlaybackState(HWND hwnd)
|
||||||
case MCI_MODE_PLAY:
|
case MCI_MODE_PLAY:
|
||||||
{
|
{
|
||||||
mciGeneric.dwCallback = (DWORD_PTR)hwnd;
|
mciGeneric.dwCallback = (DWORD_PTR)hwnd;
|
||||||
mciError = mciSendCommand(wDeviceId, MCI_PAUSE, MCI_NOTIFY | MCI_WAIT, (DWORD_PTR)&mciGeneric);
|
mciError = mciSendCommand(wDeviceId, MCI_PAUSE, MCI_WAIT, (DWORD_PTR)&mciGeneric);
|
||||||
idBmp = IDB_PLAYICON;
|
idBmp = IDB_PLAYICON;
|
||||||
idCmd = IDC_PLAY;
|
idCmd = IDC_PLAY;
|
||||||
break;
|
break;
|
||||||
|
@ -838,7 +821,7 @@ TogglePlaybackState(HWND hwnd)
|
||||||
case MCI_MODE_PAUSE:
|
case MCI_MODE_PAUSE:
|
||||||
{
|
{
|
||||||
mciGeneric.dwCallback = (DWORD_PTR)hwnd;
|
mciGeneric.dwCallback = (DWORD_PTR)hwnd;
|
||||||
mciError = mciSendCommand(wDeviceId, MCI_RESUME, MCI_NOTIFY, (DWORD_PTR)&mciGeneric);
|
mciError = mciSendCommand(wDeviceId, MCI_RESUME, MCI_WAIT, (DWORD_PTR)&mciGeneric);
|
||||||
idBmp = IDB_PAUSEICON;
|
idBmp = IDB_PAUSEICON;
|
||||||
idCmd = IDC_PAUSE;
|
idCmd = IDC_PAUSE;
|
||||||
break;
|
break;
|
||||||
|
@ -1237,6 +1220,19 @@ MainWndProc(HWND hwnd, UINT Message, WPARAM wParam, LPARAM lParam)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case MM_MCINOTIFY:
|
||||||
|
{
|
||||||
|
if (wParam == MCI_NOTIFY_SUCCESSFUL)
|
||||||
|
{
|
||||||
|
StopPlayback(hwnd);
|
||||||
|
if (bRepeat)
|
||||||
|
{
|
||||||
|
StartPlayback(hwnd);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case WM_NOTIFY:
|
case WM_NOTIFY:
|
||||||
{
|
{
|
||||||
LPNMHDR pnmhdr = (LPNMHDR)lParam;
|
LPNMHDR pnmhdr = (LPNMHDR)lParam;
|
||||||
|
|
Loading…
Reference in a new issue