1 編譯選項
編譯選項有:
Translate:Translate the current active file. 翻譯當前改動的文件,用來檢查語法錯誤,不生成目標文件。
Build:Build target files. 編譯目標文件,只對更改的源文件進行一個編譯,同時生成連接可執行文件。如果是第一次編譯,會對所有的文件進行一個編譯。
Rebuild:Rebuild all target files. 對多有的文件進行一個編譯。
Batch Build:Perform a batch build. 進行批量編譯。
2 添加.c與.h文件
2.1 創建文件夾
在工程文件夾中新建一個文件User,然后在User文件中新建Src(存放.c文件)和Inc(存放.h文件)兩個文件夾。
2.2 創建源文件
new兩個空白文件,一個保存在Src文件夾中,為.c文件;另一個保存在Inc文件夾中,為.h文件。
2.3 添加分組
在工程中添加一個分組,並對分組進行命名。
2.4 在分組中添加文件
將新建的.c文件添加至分組中。
2.5 添加.h文件路徑
3 #ifndef #define #endif
創建一個頭文件后,要在.h文件中添加如下幾條語句:
#ifndef __XXX_H #define __XXX_H
#endif
上面的XXX是指該頭文件的名字,一般用大寫字母表示。例如delay.h,XXX就是DELAY。
其實這就是一個判斷語句:
判斷條件為是否定義了__XXX_H;
執行范圍在#ifndef __XXX_H至#endif中間(如果滿足if條件,就執行這個范圍里的語句);
#endif就是一個if判斷結束標志。
加這幾條判斷語句的目的:
可以避免重復編譯,例如:
a.h中包含了delay.h;
b.h中也包含了delay.h;
最后main.h中包含a.h與b.h;
那么在編譯的過程中,只有a.h中的delay.h會被編譯,后面b.h中delay不會被編譯。
4 注釋顯示亂碼的解決方法
5 在keil中添加STC芯片包的方法
使用STC-ISP軟件,如下圖所示。
/*---------------------------------------------------------------------*//* --- STC MCU Limited ------------------------------------------------*//* --- STC15F4K60S4 系列 AD轉換查詢方式舉例----------------------------*//* --- Mobile: (86)13922805190 ----------------------------------------*//* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*//* --- Tel: 86-0513-55012928,55012929,55012966-------------------------*//* --- Web: www.STCMCU.com --------------------------------------------*//* --- Web: www.GXWMCU.com --------------------------------------------*//* 如果要在程序中使用此代碼,請在程序中注明使用了STC的資料及程序 *//* 如果要在文章中應用此代碼,請在文章中注明使用了STC的資料及程序 *//*---------------------------------------------------------------------*/
//本示例在Keil開發環境下請選擇Intel的8058芯片型號進行編譯//若無特別說明,工作頻率一般為11.0592MHz
#include "reg51.h"#include "intrins.h"
#define FOSC 11059200L#define BAUD 115200
typedef unsigned char BYTE;typedef unsigned int WORD;
#define URMD 0 //0:使用定時器2作為波特率發生器 //1:使用定時器1的模式0(16位自動重載模式)作為波特率發生器 //2:使用定時器1的模式2(8位自動重載模式)作為波特率發生器
sfr T2H = 0xd6; //定時器2高8位sfr T2L = 0xd7; //定時器2低8位
sfr P1M1 = 0x91; //PxM1.n,PxM0.n =00--->Standard, 01--->push-pullsfr P1M0 = 0x92; // =10--->pure input, 11--->open drainsfr P0M1 = 0x93;sfr P0M0 = 0x94;sfr P2M1 = 0x95;sfr P2M0 = 0x96;sfr P3M1 = 0xB1;sfr P3M0 = 0xB2;sfr P4M1 = 0xB3;sfr P4M0 = 0xB4;sfr P5M1 = 0xC9;sfr P5M0 = 0xCA;sfr P6M1 = 0xCB;sfr P6M0 = 0xCC;sfr P7M1 = 0xE1;sfr P7M0 = 0xE2;
sfr AUXR = 0x8e; //輔助寄存器
sfr ADC_CONTR = 0xBC; //ADC控制寄存器sfr ADC_RES = 0xBD; //ADC高8位結果sfr ADC_LOW2 = 0xBE; //ADC低2位結果sfr P1ASF = 0x9D; //P1口第2功能控制寄存器
#define ADC_POWER 0x80 //ADC電源控制位#define ADC_FLAG 0x10 //ADC完成標志#define ADC_START 0x08 //ADC起始控制位#define ADC_SPEEDLL 0x00 //540個時鍾#define ADC_SPEEDL 0x20 //360個時鍾#define ADC_SPEEDH 0x40 //180個時鍾#define ADC_SPEEDHH 0x60 //90個時鍾
void InitUart();void InitADC();void SendData(BYTE dat);BYTE GetADCResult(BYTE ch);void Delay(WORD n);void ShowResult(BYTE ch);
void main(){ P0M0 = 0x00; P0M1 = 0x00; P1M0 = 0x00; P1M1 = 0x00; P2M0 = 0x00; P2M1 = 0x00; P3M0 = 0x00; P3M1 = 0x00; P4M0 = 0x00; P4M1 = 0x00; P5M0 = 0x00; P5M1 = 0x00; P6M0 = 0x00; P6M1 = 0x00; P7M0 = 0x00; P7M1 = 0x00;
InitUart(); //初始化串口 InitADC(); //初始化ADC while (1) { ShowResult(0); //顯示通道0 ShowResult(1); //顯示通道1 ShowResult(2); //顯示通道2 ShowResult(3); //顯示通道3 ShowResult(4); //顯示通道4 ShowResult(5); //顯示通道5 ShowResult(6); //顯示通道6 ShowResult(7); //顯示通道7 }}
/*----------------------------發送ADC結果到PC----------------------------*/void ShowResult(BYTE ch){ SendData(ch); //顯示通道號 SendData(GetADCResult(ch)); //顯示ADC高8位結果
// SendData(ADC_LOW2); //顯示低2位結果}
/*----------------------------讀取ADC結果----------------------------*/BYTE GetADCResult(BYTE ch){ ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START; _nop_(); //等待4個NOP _nop_(); _nop_(); _nop_(); while (!(ADC_CONTR & ADC_FLAG));//等待ADC轉換完成 ADC_CONTR &= ~ADC_FLAG; //Close ADC
return ADC_RES; //返回ADC結果}
/*----------------------------初始化串口----------------------------*/void InitUart(){ SCON = 0x5a; //設置串口為8位可變波特率#if URMD == 0 T2L = (65536 - (FOSC/4/BAUD)); T2H = (65536 - (FOSC/4/BAUD)) >> 8; AUXR = 0x14; //T2為1T模式, 並啟動定時器2 AUXR |= 0x01; //選擇定時器2為串口1的波特率發生器#elif URMD == 1 AUXR = 0x40; //定時器1為1T模式 TMOD = 0x00; //定時器1為模式0(16位自動重載) TL1 = (65536 - (FOSC/4/BAUD)); TH1 = (65536 - (FOSC/4/BAUD)) >> 8; TR1 = 1; //定時器1開始啟動#else TMOD = 0x20; //設置定時器1為8位自動重裝載模式 AUXR = 0x40; //定時器1為1T模式 TH1 = TL1 = (256 - (FOSC/32/BAUD)); TR1 = 1;#endif}
/*----------------------------初始化ADC----------------------------*/void InitADC(){ P1ASF = 0xff; //設置P1口為AD口 ADC_RES = 0; //清除結果寄存器 ADC_CONTR = ADC_POWER | ADC_SPEEDLL; Delay(2); //ADC上電並延時}
/*----------------------------發送串口數據----------------------------*/void SendData(BYTE dat){ while (!TI); //等待前一個數據發送完成 TI = 0; //清除發送標志 SBUF = dat; //發送當前數據}
/*----------------------------軟件延時----------------------------*/void Delay(WORD n){ WORD x;
while (n--) { x = 5000; while (x--); }}