Update ac97snd to latest version published on the forum.

git-svn-id: svn://kolibrios.org@3495 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Yogev Ezra 2013-05-06 11:06:49 +00:00
parent 286a1a9a39
commit a1dd9086b0

View File

@ -64,6 +64,8 @@ int pan =0;
DWORD status; DWORD status;
DWORD first_sync; DWORD first_sync;
DWORD PLStatus=0; //Asper+ DWORD PLStatus=0; //Asper+
byte replay=0;
byte hidden=0;
#ifdef DOCKABLE_WINDOW #ifdef DOCKABLE_WINDOW
byte thread_info[1024]; //Asper+ byte thread_info[1024]; //Asper+
@ -92,6 +94,7 @@ char header_PL[] = "PLAYLIST";
char buttons_xm[] = " Play Stop Vol- Vol+"; /* uFMOD integration */ char buttons_xm[] = " Play Stop Vol- Vol+"; /* uFMOD integration */
char buttons_wav[] = " Play Stop << >> Vol- Vol+"; /* uFMOD integration */ char buttons_wav[] = " Play Stop << >> Vol- Vol+"; /* uFMOD integration */
char button_PL[] = "PL"; //Asper+ char button_PL[] = "PL"; //Asper+
char button_R[] = "R"; //Asper+
char *buttons_text = buttons_wav; /* uFMOD integration */ char *buttons_text = buttons_wav; /* uFMOD integration */
void play_xm(); /* uFMOD integration */ void play_xm(); /* uFMOD integration */
@ -223,10 +226,46 @@ void _stdcall pl_thread_proc(void *param)
exit(); exit();
break; break;
case 0x19: //P - playlist
switch (PLStatus)
{ case 0x00: //PL not started.
pl_tid=create_thread(pl_thread_proc, 0, 4096);
PLStatus=0x12;
break;
case 0x01: //PL started, but hidden.
PLStatus=0x12;
break;
case 0x02: //PL started and showed.
PLStatus=0x11;
break;
}
break;
case 0x1C: //Enter case 0x1C: //Enter
currActive=currFirstShowed+currSelected-1; currActive=currFirstShowed+currSelected-1;
status = ST_TRACK; status = ST_TRACK;
break; break;
case 0x2C: //Z - previous
currActive-=2;
status = ST_TRACK;
break;
case 0x2D: //X - play
status = ST_PLAY;
break;
case 0x2E: //C - pause
break;
case 0x2F: //V - stop
status = ST_STOP;
break;
case 0x30: //B - next
status = ST_TRACK;
break;
case 0x47: //Home case 0x47: //Home
if(l_vol < 0) if(l_vol < 0)
{ l_vol+=100; { l_vol+=100;
@ -239,6 +278,7 @@ void _stdcall pl_thread_proc(void *param)
{ {
if (currFirstShowed>0) if (currFirstShowed>0)
currFirstShowed--; currFirstShowed--;
else break;
ShowPLContent(pl_buff); ShowPLContent(pl_buff);
break; break;
} }
@ -289,16 +329,9 @@ void _stdcall pl_thread_proc(void *param)
PLStatus=0x00; PLStatus=0x00;
exit(); exit();
} }
for (i=0;i<PL_MAX_SHOWN_ITEMS;i++) currActive=currFirstShowed+button-0x10-1;
{
if (button==0x10+i)
{
currActive=currFirstShowed+i-1;
status = ST_TRACK; status = ST_TRACK;
break; break;
}
}
break;
case EV_IPC: case EV_IPC:
*ipc_buff='\0'; *ipc_buff='\0';
ShowPLContent(pl_buff); ShowPLContent(pl_buff);
@ -344,9 +377,9 @@ int GetFileNameFromPL(const char *plbuff, int index, char *name)
count++; count++;
if (count-1==index) if (count-1==index)
{ {
if (j>MAX_TEXT_WIDTH || ch=='\n') if (j>MAX_TEXT_WIDTH || ch=='\r' || ch=='\n')
{ {
name[j-1]='\0'; name[j]='\0';
break; break;
} }
if (ch=='\\') ch='/'; if (ch=='\\') ch='/';
@ -397,22 +430,27 @@ int ShowPLContent(char *filebuffer)
return 1; return 1;
} }
//Asper_____________________Play List code end_____________________________ //Asper_____________________Play List code end_____________________________
void redraw_R_button() //Asper +
{
DWORD rc = 0xA0FFA0; //R button text color
if (!replay) rc = 0x404040;
write_text(14,74,rc|FONT0,button_R,sizeof(button_R)-1);
}
void update_dinamic_content() //Asper + void update_dinamic_content() //Asper +
{ {
int len; /* uFMOD integration */ int len = strlen(filename);
if (len > 47) len = 47;
draw_bar(7,41,286,11,main_wc); draw_bar(7,41,286,11,main_wc);
draw_bar(7,55,286,11,main_wc); draw_bar(7,55,286,11,main_wc);
len = strlen(filename); /* uFMOD integration */ write_text(11,57,0x00FF20|FONT0, filename, len);
if(len > 47) len = 47; /* uFMOD integration */
write_text(11,57,0x00FF20|FONT0, filename, len); /* uFMOD integration */
} }
void draw_window() void draw_window()
{ {
BeginDraw(); BeginDraw();
if (!hidden)
{
DrawWindow(100,100,299,main_wh,main_wc,4,0,0,0); //Asper+ DrawWindow(100,100,299,main_wh,main_wc,4,0,0,0); //Asper+
make_button(7,24,45,13, 0x10|BT_NORMAL,main_bc); make_button(7,24,45,13, 0x10|BT_NORMAL,main_bc);
@ -423,6 +461,7 @@ void draw_window()
make_button(248,24,45,13, 0x15|BT_NORMAL,main_bc); make_button(248,24,45,13, 0x15|BT_NORMAL,main_bc);
make_button(268,70,25,13, 0x16|BT_NORMAL,main_bc); //Asper+ PL button make_button(268,70,25,13, 0x16|BT_NORMAL,main_bc); //Asper+ PL button
make_button(10,70,12,13, 0x17|BT_NORMAL,main_wc); //Asper+ R button
make_button(7,41,286,11, 0x30|BT_HIDE|BT_NOFRAME,main_wc); make_button(7,41,286,11, 0x30|BT_HIDE|BT_NOFRAME,main_wc);
@ -433,6 +472,8 @@ void draw_window()
write_text(276,74,main_wc|FONT0,button_PL,sizeof(button_PL)-1); //Asper+ PL button text write_text(276,74,main_wc|FONT0,button_PL,sizeof(button_PL)-1); //Asper+ PL button text
write_text(275,73,0xA0FFA0|FONT0,button_PL,sizeof(button_PL)-1); //Asper+ write_text(275,73,0xA0FFA0|FONT0,button_PL,sizeof(button_PL)-1); //Asper+
redraw_R_button();
}
EndDraw(); EndDraw();
}; };
@ -624,10 +665,15 @@ int main(int argc, char *argv[])
int err, ver; int err, ver;
int i; int i;
char ipc_msg[2]="\0\0"; char ipc_msg[2]="\0\0";
strcpy (full_filename, argv[1]);
pl_items_number=0; pl_items_number=0;
if (argv[1][0]=='-' && argv[1][1]=='h')
{
hidden = 1;
argv[1]+=3;
}
strcpy (full_filename, argv[1]);
InitHeap(1024*1024); InitHeap(1024*1024);
if(err = InitSound(&ver)) if(err = InitSound(&ver))
@ -663,7 +709,13 @@ int main(int argc, char *argv[])
if (LoadFile(full_filename)) if (LoadFile(full_filename))
status = ST_PLAY; status = ST_PLAY;
} }
else status = ST_STOP; else
{
currSelected=currFirstShowed=0;
currActive=-1;
if (!replay) status = ST_STOP;
continue;
}
//Update ac97snd and PL windows //Update ac97snd and PL windows
i=currActive-currFirstShowed; i=currActive-currFirstShowed;
@ -902,6 +954,46 @@ void _stdcall thread_proc(void *param)
case 0x01: //Esc case 0x01: //Esc
status = ST_EXIT; status = ST_EXIT;
exit(); exit();
break;
case 0x13: //R - repeat on/off
replay=!replay;
redraw_R_button();
break;
case 0x19: //P - playlist
switch (PLStatus)
{ case 0x00: //PL not started.
pl_tid=create_thread(pl_thread_proc, 0, 4096);
PLStatus=0x12;
break;
case 0x01: //PL started, but hidden.
PLStatus=0x12;
break;
case 0x02: //PL started and showed.
PLStatus=0x11;
break;
}
break;
case 0x2C: //Z - previous
currActive-=2;
status = ST_TRACK;
break;
case 0x2D: //X - play
status = ST_PLAY;
break;
case 0x2E: //C - pause
break;
case 0x2F: //V - stop
status = ST_STOP;
break;
case 0x30: //B - next
status = ST_TRACK;
break; break;
case 0x47: //Home case 0x47: //Home
@ -944,7 +1036,7 @@ void _stdcall thread_proc(void *param)
case 0x10: case 0x10:
status = ST_PLAY; status = ST_PLAY;
continue; break;//continue;
case 0x11: case 0x11:
status = ST_STOP; status = ST_STOP;
@ -987,6 +1079,10 @@ void _stdcall thread_proc(void *param)
break; break;
} }
break; break;
case 0x17: //Asper+ PL button action
replay=!replay;
redraw_R_button();
break;
case 0x30: case 0x30:
if(status==ST_DONE) if(status==ST_DONE)
@ -1182,7 +1278,7 @@ void uint2str(unsigned int value, char *string)
///********* ///*********
void *__cdecl memmove ( void * dst, const void * src, unsigned int count) /* uFMOD integration */ void *memmove ( void * dst, void * src, unsigned int count) /* uFMOD integration */
{ void *ret; { void *ret;
ret = dst; ret = dst;