当前位置:首页 > 单片机 > 单片机
[导读]这个是程序是来自我以前开发的一个项目,其中里面的的void ps_send(uchar x) 这个函数,便可实现向电脑发送按键的数据 你只要对照 ps2 扫描码的表填入适当的参数即可 #include "STC89C51.H" #include"keyboard.h"

这个是程序是来自我以前开发的一个项目,其中里面的的void ps_send(uchar x) 这个函数,便可实现向电脑发送按键的数据 你只要对照 ps2 扫描码的表填入适当的参数即可
#include "STC89C51.H"
#include"keyboard.h"
#include<INTRINS.H>
#define nop()  _nop_()

uchar *receive_buf;//接收来自计算机的数据

//uchar key;
unsigned char key_buf[21];
/******延时子程序********/
void delay_ms(uchar a)
{uchar i;
uchar j;

for(j=0;j<a;j++)
for(i=200;i>0;i--);
}
 
void delay_us(void)//30us
{uchar i;

  for(i=0;i<7;i++)
 {  _nop_();
 }
}

/************行列转换成索引号*****************/
/*
uchar code_chang(uchar ini_code)
 {uchar  i;
i=ini_code;
 switch(i)
     {case 0x01:return(1);break;
     case 0x02:return(2);break;
     case 0x04:return(3);break;
     case 0x08:return(4);break;
     case 0x10:return(5);break; 
   default:;
     }
  
  
 }
*/
//初始化按键端口
void init_key(void)
{
  
unsigned char i=0;
 
//右按键板
P2=0xff;

//左按键板
P0=0xff;

k_num_5 = 1;
k_num_4 = 1;
k_num_7 = 1;
k_num_8 = 1;
k_num_9 = 1;
//   led=0;
   for(i=0;i<21;i++)
   {
       key_buf[i]=1;
   
   }

 
}

//读按键值并将其转换为索引号
unsigned char read_key(void)
{unsigned char i;
 key_buf[0]=k_esc;
 key_buf[1]=k_F1;
 key_buf[2]=k_F3;
 key_buf[3]=k_F2;
 key_buf[4]=k_F5;
 key_buf[5]=k_F4;
 key_buf[6]=k_menu;
 key_buf[7]=k_num_lock;
 
 key_buf[8]=k_num_6;
 key_buf[9]=k_num_1;
 key_buf[10]=k_num_2 ;
 key_buf[11]=k_num_3 ;
 key_buf[12]=k_num_0;
 key_buf[13]=k_del;
 key_buf[14]=k_enter;
 key_buf[15]=k_back;
 key_buf[16]=k_num_5;
 
 key_buf[17]=k_num_4;
 key_buf[18]=k_num_7;
 key_buf[19]=k_num_8;
 key_buf[20]=k_num_9;
 
 for(i=0;i<21;i++) 
   {if(0==key_buf[i])
   {
    key_buf[i]=1;
    return i;
    break;
   }
    }
}

 /********代码转换**************/
uchar change_code(uchar key)   //返回一个ASCII键值
{uchar i;
 static bit shitf_direct=0,key_flat=1;

i=key;
 if(7==i&&1==key_flat)
 {key_flat=0;
 shitf_direct=1;
 }
 else if(7==i&&0==key_flat)
 {key_flat=1;
 shitf_direct=0;
 }
 else
 {}
    if ( 1==shitf_direct)//转到方向盘(1为方向盘,0为数字盘)
 {   lock_LED =0;
 switch(i)

   {
   case 12:return(0x2D);break;//insert
      case 9:return(0x23);break;//end
      case 10:return(0x28);break;//down
   case 11:return(0x22);break;//pagedown
   case 17:return(0x25);break;//left
   case 16:return(0x0C);break;//NC
   case 8:return(0x27);break;//right
   case 18:return(0x24);break;//home
   case 19:return(0x26);break;//up
   case 20:return(0x21);break;//pageup
   default:;
  }
 }
 else
       {lock_LED =1;
    return(trdata[i]);
    }
}
/*************键盘扫描*****************/
/*
void int1() interrupt 2 using 1
{//uchar scankb(void)
uchar sccode,recode;
 
 if((P0&0x0f)!=0x0f)//有键按下
   {delay_ms(10);
    if((P0&0x0f)!=0x0f)//仍然有键按下
      {recode=P0|0xf0; //列号保存
     P0=0x0f;
       sccode=0xfe;
    while((sccode&0x40)!=0)//移位没完
        {
       P2=sccode;//行扫描开始
       if(P0 != 0x0F) //若在该行
       {
     P0=0x0f;
           P2=0;
          //return(code_chang(~sccode)+5*code_chang(~recode));//返回Keyword
       key=code_chang(~sccode)+5*code_chang(~recode);break;
        }
          else
    {sccode=(sccode<<1)|0x01;}//不在该行则扫下一行
     }
    }
   }
// return(0);
}

*/


/** ps/2发送数据   ***/
void ps_send(uchar x)
{  uchar i,temp,char_temp;
  bit flat_check=1;
 delay_ms(3);
 temp=x;
 for(i=0;i<8;i++)
 {char_temp=temp&0x01;
  if(char_temp==0x01)
  {flat_check=!flat_check;
  }
 temp>>=1;
 }
 k_clk = 1;

 while(!k_clk);

 k_clk=1;
 k_data=1;
 if(k_clk==1)
 {delay_us();//30us
 }
 if(k_clk==1&&k_data==1)
 {k_data=0;
 nop();nop();nop();nop();nop();nop();nop();nop();nop();nop();//delay10us;
    k_clk=0;
 nop();nop();nop();nop();nop();//delay5us;
 temp=x;
  for(i=0;i<8;i++)
  {k_clk=1;
  nop();nop();nop();nop();nop();//delay5us;
  char_temp=temp&0x01;
   if(char_temp==0x01)
   {
   k_data=1;
   }
   else
   {
   k_data=0;
   }
  nop();nop();nop();nop();nop();nop();nop();nop();nop();nop();//delay10us;
  k_clk=0;
  nop();nop();nop();nop();nop();//delay5us;
  temp>>=1;
  }
 k_clk=1;
 nop();nop();nop();nop();nop();//delay5us;
 k_data=flat_check;
 nop();nop();nop();nop();nop();nop();nop();nop();nop();nop();//delay10us;
 k_clk=0;
 nop();nop();nop();nop();nop();//delay5us;
 k_clk=1;
 nop();nop();nop();nop();nop();//delay5us;
 k_data=1;
 nop();nop();nop();nop();nop();nop();nop();nop();nop();nop();//delay10us;
 k_clk=0;
 nop();nop();nop();nop();nop();//delay5us;
 k_clk=1;
 delay_us();
 k_clk=1;
 k_data=1;
 if(k_clk==1&&k_data==0)
 {
 return;//goto receive PC of data
 }
 }
}

 

/*****************************************************************************************
串行通讯
采用11位带奇偶效检串口异步通信
******************************************************************************************/
/******串口发送***********/
/*
void series_sent(uchar keyword)
{uchar i,key_L;
 uint j;
 bit odd=0;
 key_L=keyword;
 for(i=0;i<8;i++)
 {odd=odd ^ key_L^7;
 key_L<<=1;
 }
SBUF=keyword;
TB8=odd;//odd=1为奇数 ,odd=0为偶数
while(TI==0);
for(j=0;j<500;j++);
  
}

*/

/****************串口中断***************************/
/*
void UART() interrupt 4 using 2
{bit odd,odd_check;
uchar i, buf;

if(RI)
{
 buf=SBUF;
 odd=RB8;
 for(i=0;i<8;i++)
 {odd_check=odd_check ^ buf ^7;
 buf<<=1;
 }
 if(odd_check!=odd)//校验出错发送错误代码0x55
 {
  
  SBUF=0x55;//错误代码0x55
  while(!TI);//等待发送完成
  TI=0;//清除发送标志
 }
 else
 {*receive_buf=SBUF;//将来自计算机的数据保存
 }
 RI=0;//清除接收标志
}
}

*/
/************************************************************
//mcu初始化
**************************************************************/
void ini(void)
{
TMOD=0X20;                /*定时器1八位自动重装*/
TL1=0XFA;TH1=0XFA;        /*12MHz,9600波特,误差8.5%*/
//SCON=0Xd8;PCON=0X10;      /*11位异步,定时器控制*/
//TR1=1;
   AUXR=0xbf;         //12T:0xbf    1T:0x40
   RCAP2H=0XFF;     //设T2为波特率发生器  12M----9600----0xFFD9
   RCAP2L=0Xd9;
   TR2=1;
// T2IE=1;
// T2RSE=1;
   ET2=1;
   TCLK=1;
   RCLK=1;
   TMOD=0x11;  //设T1为定时方式1,设T0为定时方式1
   TH1=0xec;  //5ms
   TL1=0X78;
   TH0=0xff;  //100us  ff9b
   TL0=0xaa;
   PCON=0x00;
//   SCON=0xD0;       //串行口工作方式3
//   ES=1;            //开串行口中断
   EA=1;
   ET0=1;           //T0开中断
   ET1=1;           //T1开中断
   IT0=1;  //外部中断0边沿触发,
   EX0=1;//中断允许
   IT1=1;  // 外部中断1边沿触发?
   EX1=1;//中断允许
   TR1=1;           //启动T1
   TR0=1;           //启动T0
}

/**********看门狗***************/
void watchdog()
{
 WDT_CONTR = 0x3f;
}

/***************************/
void main(void)
{uchar chg_code,key;


ini();
init_key();
watchdog();//看门狗

 for(;;)
 {
// key=scankb();//键盘扫描
    key= read_key();
 chg_code=change_code(key);//代码转换
// series_sent(chg_code);//串口发送
 ps_send(chg_code);//PS/2发送
 watchdog();
 }

}
 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭