LPC2000定时器实验:蜂鸣器控制与PWM音乐输出

2星 需积分: 16 2 下载量 89 浏览量 更新于2024-09-09 收藏 436KB DOCX 举报
本实验主要针对LPC2000系列ARM7微控制器的定时器功能进行深入探究,旨在帮助学生熟悉定时器的基本设置以及匹配输出的应用。实验包括三个部分: 1. 定时器0的匹配输出控制:利用定时器0的计时功能,设置其匹配复位(TC)和中断,每0.5秒产生一次中断。通过中断服务程序,控制蜂鸣器鸣叫,中断发生时,主程序暂停,执行中断处理,改变蜂鸣器状态后,清除中断标志并返回。这个过程通过流程图(图6.3)和程序清单6.1清晰展示。 2. 定时器1的匹配输出实验:实验者需配置定时器1(MAT1.0)的匹配输出通道P0.12与蜂鸣器连接,通过跳线或杜邦线实现。这里有两种方法供选择,如图6.4所示。当定时器1达到预设值时,触发蜂鸣器发声,同时匹配中断程序会设置LED1灯闪烁,可以进一步扩展为数码管显示或调用其他已有的中断服务程序。 3. PWM音乐输出实验:在此环节,通过创建名为"Music"的新工程,利用ARMExecutableImageforLPC2131模板,设计一个包含音乐简谱和节拍数的数据结构。程序将这些信息转换为PWM信号,从而实现音乐播放功能。具体步骤包括建立music.h文件,将其添加到工程中,并编写相应的C代码来驱动PWM输出。 整个实验不仅锻炼了学生的编程技能,还涉及了中断处理、硬件连接和软件编程的综合应用,有助于加深对ARM微控制器定时器功能的理解和实践能力的提升。通过这些实际操作,学生能够更好地掌握如何在嵌入式系统中利用定时器实现各种功能,如声音控制和音乐播放。
2010-12-24 上传
在ClassWizard中响应ID为~Dlg中的WM_TIMER消息。 使用SetTimer(nIDEvent,time,NULL)来建立一个定时器,关闭定时器用KillTimer(nIDEvent)函数。 然后可以响应ON_WM_TIMER消息来响应一个定时器完成一次记时后的程序。 响应方式如下: void CTimeDlg::OnTimer(UINT nIDEvent) { if(nIDEvent==1000)//间隔为5秒 { //处理事件 } elseif(nIDEvent==1001)//间隔为10秒 { //处理事件 } CDialog::OnTimer(nIDEvent); } 以下是给出一个串口通信定时检查接收数据的部分代码 void CMyDlg::OnOpenCom() { // TODO: Add your control notification handler code here if( f_open_com==true ) { f_open_com = false; GetDlgItem(IDC_OPEN_COM)->SetWindowText("打开通信端口"); CloseHandle(hComm); KillTimer(1000); /// 关闭定时器 return ; } SetTimer(1000, 1000, NULL); ///nIDEvent==1000,time=5000ms const char *ComNo; DCB dcb; string temp("COM1"); ComNo = temp.c_str(); hComm = CreateFile( ComNo , GENERIC_READ|GENERIC_WRITE , 0 , NULL , OPEN_EXISTING , 0 , 0); if( hComm==INVALID_HANDLE_VALUE ) /// 如果端口未打开 { MessageBox("打开通信端口出错!" , "Comm Error" , MB_OK); return ; } /// 将dcb地址传入,以取得通信参数 GetCommState(hComm,&dcb); /// 得知目前通信状态 dcb.BaudRate = CBR_9600; dcb.ByteSize = 8; /// 字节为8 dcb.Parity = NOPARITY; /// Parity为None dcb.StopBits = ONESTOPBIT; /// 1个停止位 if( !SetCommState( hComm , &dcb)){ MessageBox("通信端口设置出错!" , "Set Error" , MB_OK ); CloseHandle(hComm); return; } GetDlgItem(IDC_OPEN_COM)->SetWindowText("关闭通信端口"); f_open_com = true; } void CMyDlg::OnTimer(UINT nIDEvent) { // TODO: Add your message handler code here and/or call default char inbuff[1024]; DWORD nBytesRead , dwError; COMSTAT cs; /// 取得状态 ClearCommError( hComm , &dwError , &cs); /// 数据是否大于所准备的缓冲区 if( cs.cbInQue > sizeof(inbuff) ) { PurgeComm(hComm , PURGE_RXCLEAR ); /// 清除通信端口数据 return ; } ReadFile(hComm , inbuff , cs.cbInQue , &nBytesRead , NULL ); //接收通信端口的数据 inbuff[cs.cbInQue] = '\0'; MessageBox("打开通信端口出错!" , "Comm Error" , MB_OK); m_Receive.Format("%s",inbuff); UpdateData(false); CDialog::OnTimer(nIDEvent); } 李杨: for(int i=0; ;i++ ) { ... Sleep(5); if(i>...) {AfxMessageBox("错误XXX"); return;} }//跳出后记得停止一些机器动作