方法如下:
解码 *** 作程序(一):
首先将点开关开启后,音响电源 *** 纵开关置于ON位置,如此时音响面板内的液晶显示屏显示为“SAFE”字样,则表示该音响因某种原因被锁止(蓄电供电中断,蓄电池电压过低或音响BATT电源中断)。
解码 *** 作(二):
此种车型音响的解锁密码为四位数密码,利用音响装饰面板中的“AM/FM”和“SCAN”键以及4个预置电台存储键,兼做音响的解码 *** 作输入按键。
解码 *** 作程序(三):
例如输入密码1688方法为:同时按下“AM/FM”和“SCAN”键。
按动面板 *** 作存储键中的1键,观察液晶显示屏显示出1为止。
按动面板 *** 作存储键中的2键,观察液晶显示屏显示出6为止。
按动面板 *** 作存储键中的3键,观察液晶显示屏显示出8为止。
按动面板 *** 作存储键中的4键,观察液晶显示屏显示出8为止。解码 *** 作程序(四):
如经以上 *** 作输入密码正确无误后,再同时按下音响 *** 作面板中的“AM/FM”键和“SCAN”键的同时,观察液晶显示屏会显示“SAFE”字样后,将“AM/FM”和“SCAN”两键同时放松,、稍等片刻后,音响的液晶显示屏会显示出某广播电台的频率,此时则表示该音响解锁成功,音响恢复原设计功能。
close all; clear all; clc; %关闭所有图形窗口,清除工作空间所有变量,清空命令行
I=imread('lenabmp');%待编码的矩阵
imshow(I);
thresh = graythresh(I); %自动确定二值化阈值
I2 = im2bw(I,thresh); %对图像二值化
imshow(I2);
[m,n]=size(I2); %计算矩阵大小
I2=double(I2);
p_table=tabulate(I2(:)); %统计矩阵中元素出现的概率,第一列为矩阵元素,第二列为个数,第三列为概率百分数
color=p_table(:,1)';
p=p_table(:,3)'/100; %转换成小数表示的概率
psum=cumsum(p_table(:,3)'); %计算数组各行的累加值
allLow=[0,psum(1:end-1)/100];%由于矩阵中元素只有两种,将[0,1)区间划分为两个区域allLow和 allHigh
allHigh=psum/100;
numberlow=0; %定义算术编码的上下限numberlow和numberhigh
numberhigh=1;
for k=1:m %以下计算算术编码的上下限,即编码结果
for kk=1:n
data=I2(k,kk);
low=allLow(data==color);
high=allHigh(data==color);
range=numberhigh-numberlow;
tmp=numberlow;
numberlow=tmp+rangelow;
numberhigh=tmp+rangehigh;
end
end
fprintf('算术编码范围下限为%1615f\n\n',numberlow);
fprintf('算术编码范围上限为%1615f\n\n',numberhigh);
Mat=zeros(m,n); %解码
for k=1:m
for kk=1:n
temp=numberlow<low;
temp=[temp 1];
indiff=diff(temp);
indiff=logical(indiff);
Mat(k,kk)=color(indiff);
low=low(indiff);
high=allHigh(indiff);
range=high - low;
numberlow=numberlow-low;
numberlow=numberlow/range;
end
end
#include<reg52h> //包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义
sbit IR=P3^2; //红外接口标志
#define DataPort P0 //定义数据端口 程序中遇到DataPort 则用P0 替换
sbit LATCH1=P2^6;//定义锁存使能端口 段锁存
sbit LATCH2=P2^7;// 位锁存
/------------------------------------------------
全局变量声明
------------------------------------------------/
//unsigned char code dofly_DuanMa[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};// 显示段码值0~9
unsigned char irtime;//红外用全局变量
bit irpro_ok,irok;
unsigned char IRcord[4];
unsigned char irdata[33];
/------------------------------------------------
函数声明
------------------------------------------------/
void Ir_work(void);
void Ircordpro(void);
/------------------------------------------------
定时器0中断处理
------------------------------------------------/
void tim0_isr (void) interrupt 1 using 1
{
irtime++; //用于计数2个下降沿之间的时间
}
/------------------------------------------------
外部中断0中断处理
------------------------------------------------/
void EX0_ISR (void) interrupt 0 //外部中断0服务函数
{
static unsigned char i; //接收红外信号处理
static bit startflag; //是否开始处理标志位
if(startflag)
{
if(irtime<63&&irtime>=33)//引导码 TC9012的头码,9ms+45ms
i=0;
irdata[i]=irtime;//存储每个电平的持续时间,用于以后判断是0还是1
irtime=0;
i++;
if(i==33)
{
irok=1;
i=0;
}
}
else
{
irtime=0;
startflag=1;
}
}
/------------------------------------------------
定时器0初始化
------------------------------------------------/
void TIM0init(void)//定时器0初始化
{
TMOD=0x02;//定时器0工作方式2,TH0是重装值,TL0是初值
TH0=0x00; //重载值
TL0=0x00; //初始化值
ET0=1; //开中断
TR0=1;
}
/------------------------------------------------
外部中断0初始化
------------------------------------------------/
void EX0init(void)
{
IT0 = 1; //指定外部中断0下降沿触发,INT0 (P32)
EX0 = 1; //使能外部中断
EA = 1; //开总中断
}
/------------------------------------------------
键值处理
------------------------------------------------/
void Ir_work(void)//红外键值散转程序
{
/ switch(IRcord[2])//判断第三个数码值
{
case 0x0c:DataPort=dofly_DuanMa[1];break;//1 显示相应的按键值
case 0x18:DataPort=dofly_DuanMa[2];break;//2
case 0x5e:DataPort=dofly_DuanMa[3];break;//3
case 0x08:DataPort=dofly_DuanMa[4];break;//4
case 0x1c:DataPort=dofly_DuanMa[5];break;//5
case 0x5a:DataPort=dofly_DuanMa[6];break;//6
case 0x42:DataPort=dofly_DuanMa[7];break;//7
case 0x52:DataPort=dofly_DuanMa[8];break;//8
case 0x4a:DataPort=dofly_DuanMa[9];break;//9
default:break;
} /
P1=IRcord[2];
irpro_ok=0;//处理完成标志
}
/------------------------------------------------
红外码值处理
------------------------------------------------/
void Ircordpro(void)//红外码值处理函数
{
unsigned char i, j, k;
unsigned char cord,value;
k=1;
for(i=0;i<4;i++) //处理4个字节
{
for(j=1;j<=8;j++) //处理1个字节8位
{
cord=irdata[k];
if(cord>7)//大于某值为1,这个和晶振有绝对关系,这里使用12M计算,此值可以有一定误差
value|=0x80;
if(j<8)
{
value>>=1;
}
k++;
}
IRcord[i]=value;
value=0;
}
irpro_ok=1;//处理完毕标志位置1
}
/------------------------------------------------
主函数
------------------------------------------------/
void main(void)
{
EX0init(); //初始化外部中断
TIM0init();//初始化定时器
DataPort=0xfe; //取位码 第一位数码管选通,即二进制1111 1110
LATCH2=1; //位锁存
LATCH2=0;
while(1)//主循环
{
if(irok) //如果接收好了进行红外处理
{
Ircordpro();
irok=0;
}
if(irpro_ok) //如果处理好后进行工作处理,如按对应的按键后显示对应的数字等
{
Ir_work();
}
}
}
以上就是关于红外接收端接P1——1,让接收到的数在数码管上显示,如何写解码程序。全部的内容,包括:红外接收端接P1——1,让接收到的数在数码管上显示,如何写解码程序。、QR CODE 的编码和解码的原理是怎样的,,要进行怎样的图像处理、16smart音响锁了怎么解码等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)