FreeCalypso > hg > fc-magnetite
view src/aci2/bmi/mmiMidiTest.c @ 562:adae731ae50d
aci3: implemented AT%VBAT command independent of FCHG
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 06 Jan 2019 22:33:33 +0000 |
parents | 3c2acfa1a72f |
children |
line wrap: on
line source
/******************************************************************************* Texas Instruments ******************************************************************************** This software product is the property of Texas Instruments and may not be disclosed to any third party without the express permission of the owner. ******************************************************************************** $Project name: Test MMI $Module: MIDI TEST $File: MmiMidiTest.c $Revision: 1.0 $Author: Elsa Armanet-Said Texas Instruments Nice $Date: 17/05/04 ******************************************************************************** Description: This provides the start code for the MMI ******************************************************************************** $History: MmiMidiTest.c Nov 23, 2005 REF : DR OMAPS00057378 x0039928 Bug: All MIDI files are not displayed in MMI in locosto-lite Fix: Buffer memory allocated to copy the file contents is freed properly and copying file from FFS to LFS is not terminated if error is returned for just any one file, instead it tries to copy other files. Nov 09, 2005 REF:DR OMAPS00049167 x0039928 Description: The midi files cannot be heard if the audio channel selected is 'Mono' Solution: Midi Player params are made global so that settings are retained across. Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh Description: Mp3 Ringer Implementation Solution: The Midi Ringer application has been enhanced to support mp3 as ringer. The interface function names have been modified. Sep 29,2005 REF: SPR 34407 xdeepadh Bug:Back soft key takes more time to return to the previous screen in Midi application Fix:The list creation for Midi files has been modified Aug 29, 2005 REF: SPR 33999 xdeepadh Description:Midi Application - Play all files asks for a file to be selected Solution: When the files are not selected, the current playing index is set 0. Apr 05, 2005 REF: ENH 29994 xdeepadh Description: Implementation of Generic Midi Ringer and Modification of existing Midi Test Application Solution: Generic Midi Ringer and Midi Test Application were implemented. Dec 08, 2004 REF: CRR MMI-SPR-27284 Description: MIDI Player: Back Key malfunctions in MIDI application. Solution: A window is created to hold list window. When the user presses Back key, the newly created window is deleted along with list window, bringing the control back to Midi options screen. 17/05/04 $End *******************************************************************************/ /******************************************************************************* Include files *******************************************************************************/ #define ENTITY_MFW /* includes */ #include <string.h> #include <stdio.h> #include <stdlib.h> #include "typedefs.h" #include "vsi.h" #include "pei.h" #include "custom.h" #if defined (NEW_FRAME) #include "typedefs.h" #include "vsi.h" #include "pei.h" #include "custom.h" #include "gsm.h" #include "prim.h" #else #include "STDDEFS.H" #include "custom.h" #include "gsm.h" #include "vsi.h" #endif #include "message.h" /* included for aci_cmh.h .... */ #include "aci_cmh.h" /* included for mfw_sat.h, included for MmiDummy.h, included for MmiMenu.h */ #include "mfw_mfw.h" #include "mfw_win.h" #include "mfw_icn.h" /* included for mfw_mnu.h */ #include "mfw_mnu.h" #include "mfw_tim.h" #include "mfw_kbd.h" #include "mfw_sat.h" /* included for MmiDummy.h, included for MmiMenu.h */ #include "mfw_midi.h" #include "kpd/kpd_api.h" #include "MmiBlkLangDB.h" #include "mmiColours.h" #include "MmiDialogs.h" #include "MmiDummy.h" /* included for MmiMenu.h */ #include "MmiLists.h" #include "MmiMenu.h" #include "MmiSoftKeys.h" #include "AUIEditor.h" #include "MmiMidiTest.h" #include "MmiMain.h" #include "Mmisounds.h" /******************************************************************************* internal data *******************************************************************************/ /* * Internal events */ #define MT_CREATE_EDITOR 500 #define MT_EDITOR_CANCEL 501 #define MT_EDITOR_SELECT 502 #define MT_NAME_EDITOR 503 #define MT_MNU_INIT 504 /*local defines*/ #define MT_MAX_EDITOR_LENGTH 4 #define MT_INFO_SCRN_TIMEOUT 1500 #define MT_MAX_FILES 8 // Dec 08, 2004 REF: CRR MMI-SPR-27284 // Description: MIDI Player: Back Key malfunctions in MIDI application. // E_INIT event definition #define E_INIT 1 /*editor data structure*/ typedef struct{ T_MMI_CONTROL mmi_control; MfwHnd win; MfwHnd mt_win_editor; UBYTE mt_buffer[MT_MAX_EDITOR_LENGTH+1]; USHORT mt_voice_number; } T_MMI_MT_Editor_Data; /*menu data structure definition*/ typedef struct { T_MMI_CONTROL mmi_control; T_MFW_HND win; T_MFW_HND kbd; T_MFW_HND kbd_long; T_MFW_HND mt_menu; T_MFW_HND parent; // Dec 08, 2004 REF: CRR MMI-SPR-27284. Member "parent" added T_VOID_FUNC func_cb; T_VOID_FUNC cancel_cb; UBYTE mt_num_file; UBYTE mt_file_count; ListCbFunc mt_list_cb; UBYTE mt_list_idx; UBYTE IsMfwInit; ListMenuData * menu_list_data; //Sep 29,2005 REF: SPR 34407 xdeepadh }T_mt_menu; /*global menu data*/ T_mt_menu mt_menu_data = {0}; extern UBYTE mfw_player_exit_flag;//Flag to check playall is selected. extern int mfw_player_currently_playing_idx;//Stores the index of the current selected file extern UBYTE mfw_player_playback_loop_flag;//Flag to check whether loop is on /off // Nov 23, 2005 REF : DR OMAPS00057378 x0039928 // IsMidiInit variable decides whether to copy files from FFS to LFS extern UBYTE IsMidiInit; /******************************************************************************* Local prototypes *******************************************************************************/ static void midi_mt_menu_list_listmnu_cb(T_MFW_HND Parent, ListMenuData * ListData); static void mmi_midi_test_editor_cb(T_MFW_HND win, USHORT identifier, SHORT reason); //Sep 29,2005 REF: SPR 34407 xdeepadh static T_MFW_HND mmi_midi_test_build_Menu( MfwHnd parent_window); /*default static menu*/ static MfwMnuAttr menuMtSearchListAttr = { &menuArea, MNU_LEFT | MNU_LIST | MNU_CUR_LINE, /* centered page menu */ -1, /* use default font */ NULL, /* with these items (filled in later) */ 0, /* number of items (filled in leter) */ COLOUR_LIST_XX, /* Colour */ TxtNull, /* Hdr Id */ NULL, /* Background */ MNUATTRSPARE /* unused */ }; /******************************************************************************* $Function: mmi_midi_test_show_info $Description: Display the Dialog $Returns: $Arguments: *******************************************************************************/ static MfwHnd mmi_midi_test_show_info(T_MFW_HND parent, int str1, int str2, T_VOID_FUNC callback) { T_DISPLAY_DATA display_info; TRACE_FUNCTION ("mmi_midi_test_show_info()"); /* ** Create a timed dialog to display the Message "Failed" */ dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, str1, str2, COLOUR_STATUS); dlg_initDisplayData_events( &display_info, callback, MT_INFO_SCRN_TIMEOUT, KEY_LEFT | KEY_CLEAR | KEY_HUP); return info_dialog(parent, &display_info); } /******************************************************************************* $Function: midi_stop_player $Description:Stops the Midi file playing $Returns: $Arguments:m, menu being activated, i, item in menu *******************************************************************************/ GLOBAL int midi_stop_player (MfwMnu* m, MfwMnuItem* i) { TRACE_FUNCTION ("midi_stop_player()"); if(mfw_player_exit_flag == PLAYER_EXIT_FLAG_FALSE) mfw_player_exit_flag = PLAYER_EXIT_FLAG_TRUE; mfw_player_stop(sounds_midi_player_stop_cb); return 1; } /******************************************************************************* $Function: mmi_mt_add_selected_file $Description: display info message to let user know that file was selected $Returns: MFW_EVENT_CONSUMED $Arguments: *******************************************************************************/ static int mmi_mt_add_selected_file(MfwMnu* m, MfwMnuItem* i) { mmi_midi_test_show_info(0, TxtMidiFileSelected, TxtNull, NULL); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_midi_test_editor_cb $Description: This function provides the callback functionality to an editor for Midi test $Returns: None $Arguments: *******************************************************************************/ static void mmi_midi_test_editor_cb(T_MFW_HND win, USHORT identifier, SHORT reason) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_MMI_MT_Editor_Data* dev_name_data = (T_MMI_MT_Editor_Data *)win_data->user; UBYTE * editor_buffer = NULL; SHORT max_edit_size = 0; T_MFW_HND editor_win; T_MFW_HND parent; TRACE_FUNCTION ("mmi_midi_test_editor_cb()"); if (identifier == MT_NAME_EDITOR) { editor_buffer = dev_name_data->mt_buffer; max_edit_size = MT_MAX_EDITOR_LENGTH; editor_win = dev_name_data->mt_win_editor; parent = dev_name_data->win; } else { TRACE_FUNCTION ("mmi_midi_test_editor_cb() : Unknown Identifier"); /* ** if this isn't one of the "recognised" editors leave now! */ return; } switch (reason) { case INFO_KCD_LEFT: { /* ** If there is no string entered, treat this as if it was a "Cancel" */ if (editor_buffer[0] == 0x00) { /* ** Send a "Cancel" to the Midi test window */ SEND_EVENT(parent, MT_EDITOR_CANCEL, identifier, NULL); } else { /* ** Send a "Select" to the Midi test window */ SEND_EVENT(parent, MT_EDITOR_SELECT, identifier, NULL); } } break; case INFO_KCD_RIGHT: if (strlen((char *)editor_buffer) == 0) { /* ** Send a "Cancel" to the Midi test window */ SEND_EVENT(parent, MT_EDITOR_CANCEL, identifier, NULL); } break; case INFO_KCD_HUP: /* ** Set the buffer to NULLS */ memset(editor_buffer, 0x00, max_edit_size); /* ** Send a "Cancel" to the Midi test window */ SEND_EVENT(parent, MT_EDITOR_CANCEL, identifier, NULL); break; default: /* otherwise no action to be performed */ break; } } /******************************************************************************* $Function: mmi_midi_test_editor_destroy $Description: This function performs the necessary steps to remove the window handling the voice number editor, tidying up all allocated resources. $Returns: MfwResOk : Success MfwResIllHnd : Illegal Window Handler provided $Arguments: win : Window to be destroyed *******************************************************************************/ MfwRes mmi_midi_test_editor_destroy(T_MFW_HND win) { T_MFW_WIN * win_data; T_MMI_MT_Editor_Data * data; TRACE_FUNCTION ("mmi_midi_test_editor_destroy"); if (win == (void *)0) return MfwResIllHnd; win_data = ((T_MFW_HDR *) win)->data; data = (T_MMI_MT_Editor_Data *)win_data->user; /* ** Destroy the Window */ win_delete(data->win); /* ** Free the dynamically allocated memory */ mfwFree((U8 *)data, (U16)sizeof(T_MMI_MT_Editor_Data)); return MfwResOk; } /******************************************************************************* $Function: mmi_midi_test_editor_cntrl $Description: This is the dialog control function for the voice number selection Window. It receives the signals from the MFW and determines what action, if any, to take. $Returns: None $Arguments: win : The pointer to the window handler, so the function can reference the dynamic user data, if any. event : The incoming event value : Generic incoming Parameter, it will be 'event' dependant parameter : Generic incoming Parameter, it will be 'event' dependant *******************************************************************************/ void mmi_midi_test_editor_cntrl (T_MFW_HND win, USHORT event, SHORT value, void * parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_MMI_MT_Editor_Data * data = (T_MMI_MT_Editor_Data *)win_data->user; T_AUI_EDITOR_DATA editor_data; SHORT mfw_midi_retVal; int voice_limit; switch (event) { case MT_CREATE_EDITOR: #ifdef NEW_EDITOR //Clear the editor buffer memset(&editor_data,'\0',sizeof(editor_data)); /* ** Initialise the editor */ AUI_edit_SetDefault(&editor_data); AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, data->mt_buffer, MT_MAX_EDITOR_LENGTH); AUI_edit_SetTextStr(&editor_data, TxtSoftSelect, TxtSoftBack, TxtMidiEnterVoiceNumber, TxtNull); AUI_edit_SetAltTextStr(&editor_data, 1, TxtNull, TRUE, TxtCancel); AUI_edit_SetEvents(&editor_data, MT_NAME_EDITOR, TRUE, FOREVER, (T_AUI_EDIT_CB)mmi_midi_test_editor_cb); data->mt_win_editor = AUI_edit_Start(data->win, &editor_data); #endif break; case MT_EDITOR_CANCEL: if (value == MT_NAME_EDITOR) { /* ** The editor will have been destroyed. Reset the Window handler */ data->mt_win_editor = (void *)0; } else { TRACE_FUNCTION ("mmi_midi_test_editor_cntrl(), MT_EDITOR_CANCEL event received with unexpected value" ); } /* ** Destroy the editor Window */ TRACE_FUNCTION ("mmi_midi_test_editor_cntrl cancel"); mmi_midi_test_editor_destroy(data->win); break; case MT_EDITOR_SELECT: if (value == MT_NAME_EDITOR) { voice_limit=atoi((char*)data->mt_buffer); TRACE_EVENT_P1("voice_limit is %d",voice_limit); if(voice_limit >32 ||voice_limit <=0) { mmi_midi_test_show_info(0, TxtError, TxtNull, NULL); } else { //translate ASCII format into integer format mfw_midi_retVal = mfw_player_midi_set_voice_limit(voice_limit); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { mmi_midi_test_show_info(0, TxtChConfigVoiceLimit, TxtSelected, NULL); } } } else { TRACE_FUNCTION ("mmi_midi_test_editor_cntrl(), MT_EDITOR_SELECT event received with unexpected value"); } TRACE_FUNCTION ("mmi_midi_test_editor_cntrl select"); /* ** Destroy the Editor Window */ mmi_midi_test_editor_destroy(data->win); break; default: TRACE_FUNCTION ("mmi_midi_test_editor_cntrl(), Unexpected Event!"); break; } } /******************************************************************************* $Function: midi_test_editor_create $Description: This function performs the necessary steps to create the a window to enter the number of voices. It will be removed, or rather remove itself on returning the data to the Mfw. $Returns: T_MFW_HND : Window Handle to the New Window, Null if failed. $Arguments: parent : pointer to the parent window. *******************************************************************************/ T_MFW_HND midi_test_editor_create(T_MFW_HND parent) { T_MMI_MT_Editor_Data *data; T_MFW_WIN * win; TRACE_FUNCTION ("midi_test_editor_create"); data = (T_MMI_MT_Editor_Data *)mfwAlloc((U16)sizeof(T_MMI_MT_Editor_Data)); if (data == (void *)0) return data; data->win = winCreate(parent, 0, E_WIN_VISIBLE, NULL); if (data->win == (void *)0) { /* ** Failed to start : Free Memory, and exit */ mfwFree((U8 *)data, (U16)sizeof(T_MMI_MT_Editor_Data)); data = (void *)0; return data; } else { /* ** Setup the Dialog control functions */ data->mmi_control.dialog = (T_DIALOG_FUNC)mmi_midi_test_editor_cntrl; data->mmi_control.data = data; win = ((T_MFW_HDR *)data->win)->data; win->user = (void *)data; } return data->win; } /******************************************************************************* $Function: mt_menu_win_cb $Description: menu window callback (implementation of softkeys) $Returns: $Arguments: *******************************************************************************/ static int mt_menu_win_cb (MfwEvt e, MfwWin *w) { T_mt_menu * data = (T_mt_menu *)w->user; MfwMnu * mnu; TRACE_FUNCTION ("mt_menu_win_cb "); switch (e) { case MfwWinVisible: mnu = (MfwMnu *)mfwControl(data->mt_menu); softKeys_displayId(TxtSoftSelect, TxtSoftBack, 0, mnu->curAttr->mnuColour ); break; default: return 0; } return 1; } /******************************************************************************* $Function: mt_menu_destroy $Description: destroy menu window $Returns: $Arguments: window to be destroyed *******************************************************************************/ static void mt_menu_destroy(MfwHnd window) { T_MFW_WIN * win_data = ((T_MFW_HDR *)window)->data; T_mt_menu * data = (T_mt_menu *)win_data->user; TRACE_FUNCTION ("mt_menu_destroy"); if (window == NULL) { return; } if (data) { win_delete(data->win); /* ** Free Memory */ mfwFree((void *)data, sizeof (T_mt_menu)); } } //Sep 29,2005 REF: SPR 34407 xdeepadh /******************************************************************************* $Function: midi_mt_menu_list_listmnu_cb $Description: destroy lists and menu in case of back softkey or menu exit $Returns: $Arguments: *******************************************************************************/ static void midi_mt_menu_list_listmnu_cb(T_MFW_HND Parent, ListMenuData * ListData) { T_MFW_WIN *win_data = ((T_MFW_HDR *)Parent)->data; T_mt_menu *data = (T_mt_menu *)win_data->user; TRACE_FUNCTION ("midi_mt_menu_list_listmnu_cb()"); if ((ListData->Reason EQ LISTS_REASON_BACK) || (ListData->Reason EQ LISTS_REASON_CLEAR) || (ListData->Reason EQ LISTS_REASON_HANGUP)) { /* ** Destroy the window --- Not sure if this is required! ... leave it out for now */ listsDestroy(ListData->win); /* ** Free the memory set aside for ALL the devices to be listed. */ if (data->menu_list_data != NULL) { FREE_MEMORY ((void *)data->menu_list_data->List, (U16)(data->mt_num_file * sizeof (T_MFW_MNU_ITEM))); FREE_MEMORY ((void *)data->menu_list_data, sizeof (ListMenuData)); } mt_menu_destroy(data->win); } //Sep 29,2005 REF: SPR 34407 xdeepadh else if(ListData->Reason EQ LISTS_REASON_SELECT) { TRACE_EVENT_P1("list position is %d",ListData->ListPosition); mt_menu_data.mt_list_idx = ListData->ListPosition; //call mfw to save selected index mfw_player_save_selected_file_idx(mt_menu_data.mt_list_idx); //display a "file selected" text here mmi_midi_test_show_info(0, TxtMidiFileSelected, TxtNull, NULL); } return; } /******************************************************************************* $Function: midi_test_set_loop_on $Description: set loop on $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_set_loop_on (MfwMnu* m, MfwMnuItem* i) { SHORT mfw_midi_retVal; TRACE_FUNCTION ("midi_test_set_loop_on()"); mfw_midi_retVal = mfw_player_set_loop_on(); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { TRACE_FUNCTION ("midi_test_set_loop_on(): Riviera Failed"); mmi_midi_test_show_info(0, TxtMidiOptionNotImplemented, TxtNull, NULL); } else { mmi_midi_test_show_info(0, TxtMidiLoopOn, TxtNull, NULL); } return 1; } /******************************************************************************* $Function: midi_test_set_loop_off $Description: set loop off $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_set_loop_off (MfwMnu* m, MfwMnuItem* i) { SHORT mfw_midi_retVal; TRACE_FUNCTION ("midi_test_set_loop_off()"); mfw_midi_retVal = mfw_player_set_loop_off(); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { TRACE_FUNCTION ("midi_test_set_loop_off(): Riviera Failed"); mmi_midi_test_show_info(0, TxtMidiOptionNotImplemented, TxtNull, NULL); } else { mmi_midi_test_show_info(0, TxtMidiLoopOff, TxtNull, NULL); } return 1; } /******************************************************************************* $Function: midi_test_set_channel_mono $Description: set channels to mono $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_set_channel_mono (MfwMnu* m, MfwMnuItem* i) { SHORT mfw_midi_retVal; TRACE_FUNCTION ("midi_test_set_channel_mono()"); mfw_midi_retVal = mfw_player_set_channel_mono(); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { TRACE_FUNCTION ("mfw_player_set_channel_mono(): Riviera Failed"); mmi_midi_test_show_info(0, TxtMidiOptionNotImplemented, TxtNull, NULL); } else { mmi_midi_test_show_info(0, TxtMidiMonoChannel, TxtNull, NULL); } return 1; } /******************************************************************************* $Function: midi_test_set_channel_stereo $Description: set channels to stereo $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_set_channel_stereo (MfwMnu* m, MfwMnuItem* i) { SHORT mfw_midi_retVal; TRACE_FUNCTION ("midi_test_set_channel_stereo()"); mfw_midi_retVal = mfw_player_set_channel_stereo(); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { TRACE_FUNCTION ("mfw_player_set_channel_stereo(): Riviera Failed"); mmi_midi_test_show_info(0, TxtMidiOptionNotImplemented, TxtNull, NULL); } else { mmi_midi_test_show_info(0, TxtMidiStereoChannel, TxtNull, NULL); } return 1; } /******************************************************************************* $Function: midi_test_set_speaker $Description: set audiopath to speaker $Returns: $Arguments: menu, menu item *******************************************************************************/ GLOBAL int midi_test_set_speaker (MfwMnu* m, MfwMnuItem* i) { SHORT mfw_midi_retVal; TRACE_FUNCTION ("midi_test_set_speaker()"); mfw_midi_retVal=mfw_player_set_speaker(); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { TRACE_FUNCTION ("midi_test_set_speaker(): Failed"); mmi_midi_test_show_info(0, TxtMidiOptionNotImplemented, TxtNull, NULL); } else { mmi_midi_test_show_info(0, TxtMidiSpeaker, TxtNull, NULL); } return 1; } /******************************************************************************* $Function: midi_test_set_headset $Description: set audiopath to headset $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_set_headset (MfwMnu* m, MfwMnuItem* i) { SHORT mfw_midi_retVal; TRACE_FUNCTION ("midi_test_set_headset()"); mfw_midi_retVal=mfw_player_set_headset(); if(mfw_midi_retVal != MFW_PLAYER_TEST_OK) { TRACE_FUNCTION ("midi_test_set_headset(): Failed"); mmi_midi_test_show_info(0, TxtMidiOptionNotImplemented, TxtNull, NULL); } else { mmi_midi_test_show_info(0, TxtMidiHeadset, TxtNull, NULL); } return 1; } /******************************************************************************* $Function: midi_test_cc_voice_limit $Description:Creates the Editor for entering the voice limit number $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_cc_voice_limit (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfw_parent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_MMI_MT_Editor_Data * data = (T_MMI_MT_Editor_Data *)(win_data->user); TRACE_FUNCTION ("midi_test_cc_voice_limit()"); data->mt_win_editor = midi_test_editor_create(win); if (data->mt_win_editor != (void *)0) { SEND_EVENT(data->mt_win_editor, MT_CREATE_EDITOR, 0, (void *)NULL); } else { TRACE_FUNCTION ("midi_test_cc_voice_limit() : Unable to create Editor Win!"); } return 1; } /******************************************************************************* $Function: midi_test_play $Description:Starts Playing a midi file $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_play (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfw_parent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_MMI_MT_Editor_Data * data = (T_MMI_MT_Editor_Data *)(win_data->user); T_AS_PLAYER_TYPE player_type; #ifdef FF_MIDI_LOAD_FROM_MEM T_MELODY melody_data; #else char* midi_file; #endif TRACE_FUNCTION ("midi_test_play()"); //If no file is selected inform the user if(mfw_player_currently_playing_idx < 0) { mmi_midi_test_show_info(0, TxtMidiSelectFile, TxtNull, NULL); return 1; } //flag set to 1 means we only play the currently selected file mfw_player_exit_flag = PLAYER_EXIT_FLAG_TRUE; //Play the midi player with high volume. #ifdef FF_MIDI_RINGER #ifdef FF_MIDI_LOAD_FROM_MEM melody_data=sounds_midi_return_memory_location(mfw_player_currently_playing_idx); player_type=mfw_ringer_deduce_player_type(melody_data.melody_name); mfw_player_start_memory(player_type,(UINT32*)melody_data.melody,melody_data.melody_size,(UBYTE)AS_VOLUME_HIGH,mfw_player_playback_loop_flag,sounds_midi_player_start_cb); #else midi_file=sounds_midi_return_file_name(mfw_player_currently_playing_idx); player_type=mfw_ringer_deduce_player_type(midi_file); mfw_player_start_file(player_type,midi_file,(UBYTE)AS_VOLUME_HIGH,mfw_player_playback_loop_flag,sounds_midi_player_start_cb); #endif #endif return 1; } /******************************************************************************* $Function: midi_test_play_all $Description:Plays all the midi files in the FFS one after the other $Returns: $Arguments:menu, menu item *******************************************************************************/ GLOBAL int midi_test_play_all (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfw_parent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_MMI_MT_Editor_Data * data = (T_MMI_MT_Editor_Data *)(win_data->user); T_AS_PLAYER_TYPE player_type; int numberOfMelodies=0; #ifdef FF_MIDI_LOAD_FROM_MEM T_MELODY melody_data; #else char* midi_file; #endif TRACE_FUNCTION ("midi_test_play_all()"); //Aug 29, 2005 REF: SPR 33999 xdeepadh //If the files are not populated, then populate the array and then playall the files. // Nov 23, 2005 REF : DR OMAPS00057378 x0039928 // IsMidiInit variable decides whether to copy files from FFS to LFS if(IsMidiInit==0) { sounds_midi_init(); IsMidiInit = 1; } numberOfMelodies = sounds_midi_return_file_number(); TRACE_EVENT_P1("numberOfMelodies for midi_test_play_all is %d",numberOfMelodies); if(numberOfMelodies <= 0) { mmi_midi_test_show_info(0, TxtMidiFileNotLoaded, TxtNull, NULL); return 1 ; } if(mfw_player_currently_playing_idx < 0) { //Aug 29, 2005 REF: SPR 33999 xdeepadh // When the files are not selected, the current playing index is set 0. mfw_player_currently_playing_idx = 0; } //set exit_flag to 0 to notify that we have to play all files mfw_player_exit_flag = PLAYER_EXIT_FLAG_FALSE; //Play the midi player with high volume. #ifdef FF_MIDI_RINGER #ifdef FF_MIDI_LOAD_FROM_MEM melody_data=sounds_midi_return_memory_location(mfw_player_currently_playing_idx); player_type=mfw_ringer_deduce_player_type(melody_data.melody_name); mfw_player_start_memory(player_type,(UINT32*)melody_data.melody,melody_data.melody_size,(UBYTE)AS_VOLUME_HIGH,FALSE,sounds_midi_player_start_cb); #else midi_file=sounds_midi_return_file_name(mfw_player_currently_playing_idx); player_type=mfw_ringer_deduce_player_type(midi_file); mfw_player_start_file(player_type,midi_file,(UBYTE)AS_VOLUME_HIGH,FALSE,sounds_midi_player_start_cb); #endif #endif return 1; } // Dec 08, 2004 REF: CRR MMI-SPR-27284 // Description: MIDI Player: Back Key malfunctions in MIDI application. // Solution: A window is created to hold list window. When the user presses Back key, the newly // created window is deleted along with list window, bringing the control back to Midi options // screen. /******************************************************************************* $Function: midi_test_files_exec_cb $Description: Call back function $Returns: none $Arguments: *******************************************************************************/ void midi_test_files_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_mt_menu * data = (T_mt_menu *)win_data->user; SHORT mfw_midi_retVal; int line; int max_file_number; int i; ListWinInfo * mnu_data = (ListWinInfo *)parameter; TRACE_FUNCTION (">>>>> midi_test_files_exec_cb()"); switch (event) { case E_INIT: TRACE_EVENT(">>>> midi_test_files_exec_cb() Event:E_INIT"); /* initialization of administrative data */ data->menu_list_data = (ListMenuData *)ALLOC_MEMORY(sizeof(ListMenuData)); if(data->menu_list_data == 0) { TRACE_EVENT("Failed memory alloc 1 "); return; } max_file_number = sounds_midi_return_file_number(); //In case no files have been loaded display info message //In case no files have been loaded return info message if(max_file_number == 0) { mmi_midi_test_show_info(0, TxtMidiFileNotLoaded, TxtNull, NULL); return; } data->menu_list_data->List = (T_MFW_MNU_ITEM *)ALLOC_MEMORY( max_file_number * sizeof(T_MFW_MNU_ITEM) ); if(data->menu_list_data->List == 0) { TRACE_EVENT("Failed memory alloc 2"); return; } //Sep 29,2005 REF: SPR 34407 xdeepadh for (i = 0; i < max_file_number ; i++) { mnuInitDataItem(&data->menu_list_data->List[i]); data->menu_list_data->List[i].flagFunc = item_flag_none; //Display the midi file names in the list data->menu_list_data->List[i].str = (char *)sounds_midi_return_file_name(data->mt_file_count++); } data->menu_list_data->ListLength =max_file_number; data->menu_list_data->ListPosition = 1; data->menu_list_data->CursorPosition = 1; data->menu_list_data->SnapshotSize = max_file_number; data->menu_list_data->Font = 0; data->menu_list_data->LeftSoftKey = TxtSoftSelect; data->menu_list_data->RightSoftKey = TxtSoftBack; data->menu_list_data->KeyEvents = KEY_ALL; data->menu_list_data->Reason = 0; data->menu_list_data->Strings = TRUE; data->menu_list_data->Attr = (MfwMnuAttr*)&menuMtSearchListAttr; //Apr 05, 2005 REF: ENH 29994 xdeepadh data->menu_list_data->Attr->hdrId = TxtMidiFileTitle; data->menu_list_data->autoDestroy = FALSE; listDisplayListMenu(win, data->menu_list_data,(ListCbFunc)midi_mt_menu_list_listmnu_cb,0); break; default: break; } } // Dec 08, 2004 REF: CRR MMI-SPR-27284 // Description: MIDI Player: Back Key malfunctions in MIDI application. // Solution: A window is created to hold list window. When the user presses Back key, the newly // created window is deleted along with list window, bringing the control back to Midi options // screen. /******************************************************************************* $Function: midi_test_files_win_cb $Description: Window event handler $Returns: MFW_EVENT_REJECTED: MFW_EVENT_CONSUMED: $Arguments: *******************************************************************************/ static int midi_test_files_win_cb (MfwEvt e, MfwWin *w) { TRACE_FUNCTION ("midi_test_files_win_cb()"); switch (e) { case MfwWinVisible: /* window is visible */ break; case MfwWinFocussed: /* input focus / selected */ case MfwWinDelete: /* window will be deleted */ default: return MFW_EVENT_REJECTED; } return MFW_EVENT_CONSUMED; } // Dec 08, 2004 REF: CRR MMI-SPR-27284 // Description: MIDI Player: Back Key malfunctions in MIDI application. // Solution: A window is created to hold list window. When the user presses Back key, the newly // created window is deleted along with list window, bringing the control back to Midi options // screen. /******************************************************************************* $Function: midi_test_files_browse $Description: This function is called when the user selects "Browse Midi Files" option $Returns: MFW_EVENT_CONSUMED $Arguments: *******************************************************************************/ GLOBAL int midi_test_files_browse( MfwMnu *m, MfwMnuItem *i ) { T_MFW_HND win; T_MFW_HND parent_win = mfw_parent(mfw_header()); int numberOfMelodies=0; TRACE_FUNCTION ("midi_test_files_browse"); // Nov 23, 2005 REF : DR OMAPS00057378 x0039928 // IsMidiInit variable decides whether to copy files from FFS to LFS if(IsMidiInit==0) { sounds_midi_init(); IsMidiInit = 1; } // Nov 09, 2005 REF:DR OMAPS00049167 x0039928 // Fix : Call the player initialize routine to set the default parameters. mfw_player_init(); numberOfMelodies = sounds_midi_return_file_number(); TRACE_EVENT_P1("numberOfMelodies is %d",numberOfMelodies); if(numberOfMelodies <= 0) { mmi_midi_test_show_info(0, TxtMidiFileNotLoaded, TxtNull, NULL); } else { win = mmi_midi_test_build_Menu(parent_win); if (win NEQ NULL) { SEND_EVENT (win, E_INIT, 0, 0); } } return MFW_EVENT_CONSUMED; } //Sep 29,2005 REF: SPR 34407 xdeepadh /******************************************************************************* $Function: mmi_midi_test_build_Menu $Description: To hold list window $Returns: Window handle $Arguments: *******************************************************************************/ static T_MFW_HND mmi_midi_test_build_Menu( MfwHnd parent_window) { T_mt_menu * data = (T_mt_menu *)mfwAlloc(sizeof (T_mt_menu)); T_MFW_WIN * win; TRACE_FUNCTION ("mmi_midi_test_build_Menu"); /* * Create window handler */ data->win = win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)midi_test_files_win_cb); if (data->win EQ NULL) { return NULL; } TRACE_EVENT("list holder window created: " ); /* * connect the dialog data to the MFW-window */ data->mmi_control.dialog = (T_DIALOG_FUNC)midi_test_files_exec_cb; data->mmi_control.data = data; win = ((T_MFW_HDR *)data->win)->data; win->user = (void *)data; data->parent = parent_window; winShow(data->win); /* * return window handle */ return data->win; }