A. 12款福克斯,新配的遙控器鑰匙為什麼只能遙控門鎖不能啟動車子
12款福克斯,新配的遙控器鑰匙只能遙控門鎖不能啟動車子的原因:除了有可能是晶元損壞,也會和遙控鑰匙或鑰匙防盜控制系統故障和轉向鎖故障有關。如果是鑰匙的晶元損壞,那麼需要去4S店或者規模大一點的汽車修理店,將鑰匙晶元配對,重新寫入晶元程序。
首先排查是如何解鎖汽車的,如果是用鑰匙直接開鎖,嘗試一下用遙控重新開鎖,然後把遙控鑰匙貼在點火開關位置,看是否能把點火開關轉到ON擋,並留意一下組合儀表上防盜指示燈是否常亮,如防盜指示燈常亮,可用專用的診斷電腦重新匹配注冊遙控鑰匙試試。
遙控鑰匙的工作方式
當車主進入鑰匙系統的感應區域內只要手觸及車門把手,其攜帶的身份識別鑰匙就會接收到汽車發送的低頻信號,如果這個信號與鑰匙中保存的身份識別信息一致,鑰匙將被喚醒。鑰匙被喚醒後將分析汽車發出的認證口令並發送相應信號,這些信號經過加密處理以提高安全性。
汽車會對接收信號和汽車內部保存的信息進行比較,如果驗證通過,汽車將打開車門鎖。一旦駕駛員進入車內,只需要簡單的按一下啟動鍵,汽車發動機就會啟動。按鍵觸發時PKE系統首先需要檢測鑰匙設備是否在車內,然後完成同樣的認證過程後才會啟動發動機。
B. 禹鼎遙控器編程器,可發自製嗎可以寫空白晶元嗎
買一條禹鼎遙控器編程線,安裝禹鼎軟體(F21,F23,F24)和編程線(PL2303)驅動就OK,下面附編程線電路圖僅供參考!
C. 怎樣將好的玩具遙控車遙控器上的晶元轉到新的遙控器里
遙控器頻率是配對的, 你僅把"晶元"移殖是沒有用的..! 當然, 如果是簡易玩具車的遙控, 只需要移過去, 重新連接天線/控制線/電源線就可以了...! (遙控器按鍵壞了? 換一個按鍵下面的"微動開關"就OK..!)
D. 想知道紅外遙控LED等遙控器方面的程序要怎麼寫
給你一個我編的紅外解碼的程序,這個程序會將接收到的紅外編碼中的8位碼通過串口發送到上位機,你可以通過串口調試助手來看看,程序是正確的,希望對你有參考價值。 ////////////////////////////////////////////////////////////////// //////////////////////////yorkWorldDream///////////////////////// ///////////////////////////////////////////////////////////////// #include"reg52.h" #define uchar unsigned char #define uint unsigned int //tc9012 uchar flag=0;//是否接到起始位標志 未接到為0 接到為1 uchar traflag=0;//翻譯是否完成標記 完成為1 uchar rec[33];//接收遙控器發送的所有數據 用來記錄兩個下降沿之間的時間 uchar recok=0;//是否接收完一幀數據標記 接收完為1 uchar sendok=0;//是否發送完畢標記 發送完成為1 uchar num=0;//變相記錄時間 uchar n=0;//rec[]中的數組定位 void timerinit();//定時器0初始化 void ruptinit();//外部中斷0初始化 void tradata();//一幀數據的翻譯 即把時間記錄轉換成0/1 void send();//把收到的數據發給上位機 void delay(); //////////////////////////定時器 中斷初始化///////////////////////////////// void timerinit()//定時器0 { TMOD=0x02;//定時器0使用方式2 TH0=0x00; TL0=0x00; EA=1; ET0=1;//定時器中斷開 TR0=1;//計時開 } void ruptinit()//外部中斷0 { EA=1; EX0=1;//外部中斷開 IT0=1;//下降沿觸發 0是電平觸發 } ////////////////////////////定時器 中斷函數////////////////////////////// void timer() interrupt 1 //系統從0x00記到0xff 每記一次時間大概為1us 記256次 即256us中斷一次 { num++;//num記錄的是256us的個數 總時間=num*256us } void rupt() interrupt 0 //外部中斷0 當遇到下降沿時觸發 { if(flag==1)//flag為1 說明收到了起始位 接下來要開始進行記錄了 { if(num>32)//時間為32*256us=8.2ms是整個起始位的時間 { n=0; } rec[n]=num;//記錄兩個下降沿之間的num值 這樣也就相當於記錄了其間的時間 num=0; n++; if(n==33)//因為前面是n++ 所以當n=33時 數組已經從0記到了32 已經記滿了 { recok=1;//標記 接收一幀數據完成 n=0; } } else//首次得到下降沿到達這里 使flag變1 用來說明收到了起始位 { flag=1; } } /////////////////////////////時間翻譯函數/////////////////////////////////////// void tradata()//一幀數據的翻譯 即把時間記錄轉換成0/1 { uchar i; for(i=1;i/0的數據時間是num=4.4 1的數據時間是num=8.8 { //記住要從rec[1]開始 因為rec[0]記錄的是引導碼的num值 if(rec[i]>6)//使用6做中間值 小於則為0 大於為1 用0/1替換rec中的數據 這樣就進行了翻譯 { rec[i]='1'; }//因為要以字元串發送 所以這里用字元形式 else rec[i]='0'; } traflag=1;//翻譯完成標記 } /////////////////////////////發送數據函數//////////////////////////////////// void send()//把收到的數據發送給上位機 具體細節不懂看串口通信 mcu to pc { uchar i; TMOD=0x20; TH1=0xfd; TL1=0xfd; TR1=1; SM0=0; SM1=1; REN=1; for(i=25;i/選擇要發送出去的數據 這里是從25開始發送的 { SBUF=rec[i]; while(!TI); TI=0; } sendok=1; } //////////////////////////////////////////////////////////////////////// void delay()//1ms { unsigned char a,b,c; for(c=1;c>0;c--) for(b=142;b>0;b--) for(a=2;a>0;a--); } void main() { timerinit();//定時器0初始化 ruptinit();//外部中斷0初始化 while(1) { if(recok==1)//接收一幀數據完成 { P1=0xfe;//燈亮一下 為了指示是否收到了數據 tradata();//翻譯數據 } delay(); if(traflag==1)//翻譯完成 { send();//發送 } delay(); if(sendok==1)//發送完成 { flag=0; traflag=0; recok=0; sendok=0; P1=0xff; timerinit(); ruptinit(); } //全部恢復初始 }
E. 如何編寫紅外遙控器 客戶碼
以下是程序,調試成功,LCD1602顯示
//本解碼程序適用於NEC的upd6121及其兼容晶元的解碼,支持大多數遙控器 實驗板採用11.0592MHZ晶振
#include<reg52.h> //包含單片機寄存器的頭文件
#include<intrins.h> //包含_nop_()函數定義的頭文件
sbit IR=P3^2; //將IR位定義為P3.2引腳
sbit RS=P2^0; //寄存器選擇位,將RS位定義為P2.0引腳
sbit RW=P2^1; //讀寫選擇位,將RW位定義為P2.1引腳
sbit E=P2^2; //使能信號位,將E位定義為P2.2引腳
sbit BF=P0^7; //忙碌標志位,,將BF位定義為P0.7引腳
sbit BEEP = P3^6; //蜂鳴器控制埠P36
unsigned char flag;
unsigned char code string[ ]= {"1602IR-CODE TEST"};
unsigned char a[4]; //儲存用戶碼、用戶反碼與鍵數據碼、鍵數據反碼
unsigned int LowTime,HighTime; //儲存高、低電平的寬度
/*****************************************************
函數功能:延時1ms
***************************************************/
void delay1ms()
{
unsigned char i,j;
for(i=0;i<10;i++)
for(j=0;j<33;j++)
;
}
/*****************************************************
函數功能:延時若干毫秒
入口參數:n
***************************************************/
void delay(unsigned char n)
{
unsigned char i;
for(i=0;i<n;i++)
delay1ms();
}
/*********************************************************/
void beep() //蜂鳴器響一聲函數
{
unsigned char i;
for (i=0;i<100;i++)
{
delay1ms();
BEEP=!BEEP; //BEEP取反
}
BEEP=1; //關閉蜂鳴器
delay(250); //延時
}
/*****************************************************
函數功能:判斷液晶模塊的忙碌狀態
返回值:result。result=1,忙碌;result=0,不忙
***************************************************/
unsigned char BusyTest(void)
{
bit result;
RS=0; //根據規定,RS為低電平,RW為高電平時,可以讀狀態
RW=1;
E=1; //E=1,才允許讀寫
_nop_(); //空操作
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
result=BF; //將忙碌標志電平賦給result
E=0;
return result;
}
/*****************************************************
函數功能:將模式設置指令或顯示地址寫入液晶模塊
入口參數:dictate
***************************************************/
void WriteInstruction (unsigned char dictate)
{
while(BusyTest()==1); //如果忙就等待
RS=0; //根據規定,RS和R/W同時為低電平時,可以寫入指令
RW=0;
E=0; //E置低電平(根據表8-6,寫指令時,E為高脈沖,
// 就是讓E從0到1發生正跳變,所以應先置"0"
_nop_();
_nop_(); //空操作兩個機器周期,給硬體反應時間
P0=dictate; //將數據送入P0口,即寫入指令或地址
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=1; //E置高電平
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=0; //當E由高電平跳變成低電平時,液晶模塊開始執行命令
}
/*****************************************************
函數功能:指定字元顯示的實際地址
入口參數:x
***************************************************/
void WriteAddress(unsigned char x)
{
WriteInstruction(x|0x80); //顯示位置的確定方法規定為"80H+地址碼x"
}
/*****************************************************
函數功能:將數據(字元的標准ASCII碼)寫入液晶模塊
入口參數:y(為字元常量)
***************************************************/
void WriteData(unsigned char y)
{
while(BusyTest()==1);
RS=1; //RS為高電平,RW為低電平時,可以寫入數據
RW=0;
E=0; //E置低電平(根據表8-6,寫指令時,E為高脈沖,
// 就是讓E從0到1發生正跳變,所以應先置"0"
P0=y; //將數據送入P0口,即將數據寫入液晶模塊
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=1; //E置高電平
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬體反應時間
E=0; //當E由高電平跳變成低電平時,液晶模塊開始執行命令
}
/*****************************************************
函數功能:對LCD的顯示模式進行初始化設置
***************************************************/
void LcdInitiate(void)
{
delay(15); //延時15ms,首次寫指令時應給LCD一段較長的反應時間
WriteInstruction(0x38); //顯示模式設置:16×2顯示,5×7點陣,8位數據介面
delay(5); //延時5ms
WriteInstruction(0x38);
delay(5);
WriteInstruction(0x38);
delay(5);
WriteInstruction(0x0C); //顯示模式設置:顯示開,有游標,游標閃爍
delay(5);
WriteInstruction(0x06); //顯示模式設置:游標右移,字元不移
delay(5);
WriteInstruction(0x01); //清屏幕指令,將以前的顯示內容清除
delay(5);
}
/************************************************************
函數功能:對4個位元組的用戶碼和鍵數據碼進行解碼
說明:解碼正確,返回1,否則返回0
出口參數:dat
*************************************************************/
bit DeCode(void)
{
unsigned char i,j;
unsigned char temp; //儲存解碼出的數據
for(i=0;i<4;i++) //連續讀取4個用戶碼和鍵數據碼
{
for(j=0;j<8;j++) //每個碼有8位數字
{
temp=temp>>1; //temp中的各數據位右移一位,因為先讀出的是高位數據
TH0=0; //定時器清0
TL0=0; //定時器清0
TR0=1; //開啟定時器T0
while(IR==0) //如果是低電平就等待
; //低電平計時
TR0=0; //關閉定時器T0
LowTime=TH0*256+TL0; //保存低電平寬度
TH0=0; //定時器清0
TL0=0; //定時器清0
TR0=1; //開啟定時器T0
while(IR==1) //如果是高電平就等待
;
TR0=0; //關閉定時器T0
HighTime=TH0*256+TL0; //保存高電平寬度
if((LowTime<370)||(LowTime>640))
return 0; //如果低電平長度不在合理范圍,則認為出錯,停止解碼
if((HighTime>420)&&(HighTime<620)) //如果高電平時間在560微秒左右,即計數560/1.085=516次
temp=temp&0x7f; //(520-100=420, 520+100=620),則該位是0
if((HighTime>1300)&&(HighTime<1800)) //如果高電平時間在1680微秒左右,即計數1680/1.085=1548次
temp=temp|0x80; //(1550-250=1300,1550+250=1800),則該位是1
}
a[i]=temp; //將解碼出的位元組值儲存在a[i]
}
if(a[2]=~a[3]) //驗證鍵數據碼和其反碼是否相等,一般情況下不必驗證用戶碼
return 1; //解碼正確,返回1
}
/*------------------二進制碼轉換為壓縮型BCD碼,並顯示---------------*/
void two_2_bcd(unsigned char date)
{
unsigned char temp;
temp=date;
date&=0xf0;
date>>=4; //右移四位得到高四位碼
date&=0x0f; //與0x0f想與確保高四位為0
if(date<=0x09)
{
WriteData(0x30+date); //lcd顯示鍵值高四位
}
else
{
date=date-0x09;
WriteData(0x40+date);
}
date=temp;
date&=0x0f;
if(date<=0x09)
{
WriteData(0x30+date); //lcd顯示低四位值
}
else
{
date=date-0x09;
WriteData(0x40+date);
}
WriteData(0x48); //顯示字元'H'
}
/************************************************************
函數功能:1602LCD顯示
*************************************************************/
void Disp(void)
{
WriteAddress(0x40); // 設置顯示位置為第一行的第1個字
two_2_bcd(a[0]);
WriteData(0x20);
two_2_bcd(a[1]);
WriteData(0x20);
two_2_bcd(a[2]);
WriteData(0x20);
two_2_bcd(a[3]);
}
/************************************************************
函數功能:主函數
*************************************************************/
void main()
{
unsigned char i;
LcdInitiate(); //調用LCD初始化函數
delay(10);
WriteInstruction(0x01);//清顯示:清屏幕指令
WriteAddress(0x00); // 設置顯示位置為第一行的第1個字
i = 0;
while(string[i] != '\0') //'\0'是數組結束標志
{ // 顯示字元 www.RICHMCU.COM
WriteData(string[i]);
i++;
}
EA=1; //開啟總中斷
EX0=1; //開外中斷0
ET0=1; //定時器T0中斷允許
IT0=1; //外中斷的下降沿觸發
TMOD=0x01; //使用定時器T0的模式1
TR0=0; //定時器T0關閉
while(1); //等待紅外信號產生的中斷
}
/************************************************************
函數功能:紅外線觸發的外中斷處理函數
*************************************************************/
void Int0(void) interrupt 0
{
EX0=0; //關閉外中斷0,不再接收二次紅外信號的中斷,只解碼當前紅外信號
TH0=0; //定時器T0的高8位清0
TL0=0; //定時器T0的低8位清0
TR0=1; //開啟定時器T0
while(IR==0); //如果是低電平就等待,給引導碼低電平計時
TR0=0; //關閉定時器T0
LowTime=TH0*256+TL0; //保存低電平時間
TH0=0; //定時器T0的高8位清0
TL0=0; //定時器T0的低8位清0
TR0=1; //開啟定時器T0
while(IR==1); //如果是高電平就等待,給引導碼高電平計時
TR0=0; //關閉定時器T0
HighTime=TH0*256+TL0; //保存引導碼的高電平長度
if((LowTime>7800)&&(LowTime<8800)&&(HighTime>3600)&&(HighTime<4700))
{
//如果是引導碼,就開始解碼,否則放棄,引導碼的低電平計時
//次數=9000us/1.085=8294, 判斷區間:8300-500=7800,8300+500=8800.
if(DeCode()==1) // 執行遙控解碼功能
{
Disp();//調用1602LCD顯示函數
beep();//蜂鳴器響一聲 提示解碼成功
}
}
EX0=1; //開啟外中斷EX0
}
F. ETCp遙控器怎麼寫碼
分別寫三種類型的碼,學習碼、固定碼與滾動碼。
固定碼:常用IC晶元:SC2260 、SC2262 、HS2260、HS2262、PT2262,地址編碼組合為:3的8次方(6561)。學習碼:代表IC:編碼:EV1527、 HS1527 、HS2240、 HTP6P20B、 HT6P20D,地址編碼組合為:2的20次方(1048576簡稱100萬組)。滾動碼常用IC晶元主要有:HCS101、HCS301、HCS300、HCS200等,地址碼編碼組合:由28位序列號、4個按鍵位、2個狀態位和32位加密值構成的一組發送66位編碼的晶元,遙控器按鍵每按一次晶元內同步計算器累計一次,從而使數據發生跳變,以此增加信息的安全性,從而使編碼截獲和重發均無效。
G. 車庫門遙控器沒有數據輸入插口如何寫入數據
你買的遙控器,據你的描述應該是焊碼或拔碼的普通固定碼遙控器,這個是要手工編碼的,一般只要和原遙控器PT2272IC上的8腳編碼一樣就可以使用。不行就得查看振盪電阻的值對不對。
H. N51如何生成遙控器
生成共有五個步驟。
一.同樣使用51單片機作為控制晶元,同樣只需要一個晶元和一個晶振電路單片機就能運行,但是注意可以將需要的引腳外拉。二.將按鍵開關的兩端,一端連接到單片機引腳,另一端接到地,接單片機的一端再通過一個10K電阻上拉到5V,也可以不上拉,親試能用,上拉的話穩定一些,能夠防干擾,按鍵數目自行而定,按照遙控器的那件分布來在洞洞板上焊接。三.藍牙信號腳要結對,只需要單片機的發射腳,即P3.1接到藍牙模塊的接收腳,注意和之前的不一樣;藍牙模塊設置成主模塊,但是注意車上的藍牙設置成從模塊,注意波特率一致。四.需要兩節18650電池(兩節7.2V),使用一個lm2940穩壓晶元就可以產生5V電壓給設備供電,或使用其他的5V電源來供電,比如說充電寶。五.啟動程序。
單片機是一種控制晶元,一個微型的計算機,加上晶振,存儲器,地址鎖存器,邏輯門,顯示器,按鈕,擴展晶元,介面等構成單片機系統。利用51單片機內部UART功能和藍牙模塊實現單片機之間的無限遙控,主要通過編程用於控制其他單片機或微機系統。
I. 51單片機遙控車編程,幫忙寫程序要求在下面
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit IN1=P1^0;
sbit IN2=P1^1;
sbit IN3=P1^2;
sbit IN4=P1^3;
sbit key1=P2^0;
sbit key2=P2^1;
sbit key3=P2^2;
void delay(uint n)
{ uint x,y;
for(x=n;x>0;x--)
for(y=110;y>0;y--);
}
void forward()
{
IN1=1;
IN2=0;
IN3=1;
IN4=0;
}
void reverse()
{
IN1=0;
IN2=1;
IN3=0;
IN4=1;
}
void left()
{
IN1=0;
IN2=0;
IN3=1;
IN4=0;
}
void right()
{
IN1=1;
IN2=0;
IN3=0;
IN4=0;
}
void stop()
{
IN1=0;
IN2=0;
IN3=0;
IN4=0;
}
void RSINTR() interrupt 4
{
if(RI==1)
{
RI=0;
if(SBUF=='A')
reverse();
else if(SBUF=='B')
forward();
else if(SBUF=='C')
left();
else if(SBUF=='D')
right();
else if(SBUF=='E')
stop();
}
}
main()
{
SCON=0x50;//允許串口接收
TMOD=0x20;
PCON=0x80;
TH1=0xfd;
TL1=0xfd;
RI=0;
TR1=1;
EA=1;
ES=1;
while(1)
{
}
}