key 4v4
#include "key4v4.h"
#include "stm32f10x.h"
#include "delay.h" /*
PA4-L1 PA0-R1
PA5-L2 PA1-R2
PA6-L3 PA2-R3
PA7-L4 PA3-R4
*/ #define R1_L GPIO_ResetBits(GPIOA,GPIO_Pin_0)
#define R2_L GPIO_ResetBits(GPIOA,GPIO_Pin_1)
#define R3_L GPIO_ResetBits(GPIOA,GPIO_Pin_2)
#define R4_L GPIO_ResetBits(GPIOA,GPIO_Pin_3) #define R1_H GPIO_SetBits(GPIOA,GPIO_Pin_0)
#define R2_H GPIO_SetBits(GPIOA,GPIO_Pin_1)
#define R3_H GPIO_SetBits(GPIOA,GPIO_Pin_2)
#define R4_H GPIO_SetBits(GPIOA,GPIO_Pin_3) #define Scanf_R1 R1_L,R2_H,R3_H,R4_H
#define Scanf_R2 R1_H,R2_L,R3_H,R4_H
#define Scanf_R3 R1_H,R2_H,R3_L,R4_H
#define Scanf_R4 R1_H,R2_H,R3_H,R4_L #define L1_Value GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_4)
#define L2_Value GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_5)
#define L3_Value GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_6)
#define L4_Value GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_7) int Scanf_Keys()
{
int return_value=-1;
//R1-->Low,R2-->High,R3-->High,R4-->High
//1,4,7,*
Scanf_R1;
if(L1_Value==0)
{
delay_ms(20);
if(L1_Value==0)
{
return_value=1;
}
} if(L2_Value==0)
{
delay_ms(20);
if(L2_Value==0)
{
return_value=4;
}
} if(L3_Value==0)
{
delay_ms(20);
if(L3_Value==0)
{
return_value=7;
}
} if(L4_Value==0)
{
delay_ms(20);
if(L4_Value==0)
{
return_value=10;
}
} //R2-->High,R2-->Low,R3-->High,R4-->High
//2,5,8,0
Scanf_R2;
if(L1_Value==0)
{
delay_ms(20);
if(L1_Value==0)
{
return_value=2;
}
} if(L2_Value==0)
{
delay_ms(20);
if(L2_Value==0)
{
return_value=5;
}
} if(L3_Value==0)
{
delay_ms(20);
if(L3_Value==0)
{
return_value=8;
}
} if(L4_Value==0)
{
delay_ms(20);
if(L4_Value==0)
{
return_value=0;
}
} //R2-->High,R2-->High,R3-->Low,R4-->High
//3,6,9,#
//3,6,9,15
Scanf_R3;
if(L1_Value==0)
{
delay_ms(20);
if(L1_Value==0)
{
return_value=3;
}
} if(L2_Value==0)
{
delay_ms(20);
if(L2_Value==0)
{
return_value=6;
}
} if(L3_Value==0)
{
delay_ms(20);
if(L3_Value==0)
{
return_value=9;
}
} if(L4_Value==0)
{
delay_ms(20);
if(L4_Value==0)
{
return_value=15;
}
} //R2-->High,R2-->High,R3-->High,R4-->Low
//a,b,c,d
//a,b,c,h
Scanf_R4;
if(L1_Value==0)
{
delay_ms(20);
if(L1_Value==0)
{
return_value=11;
}
} if(L2_Value==0)
{
delay_ms(20);
if(L2_Value==0)
{
return_value=12;
}
} if(L3_Value==0)
{
delay_ms(20);
if(L3_Value==0)
{
return_value=13;
}
} if(L4_Value==0)
{
delay_ms(20);
if(L4_Value==0)
{
return_value=14;
}
} return return_value;
} void Scanf_Init()
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOC,ENABLE); //input
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IPU;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA,&GPIO_InitStructure); //output
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA,&GPIO_InitStructure); }
/*
3f,6 ,5b,4f,66,6d,7d,7 ,7f,6f,27,4f,7f,27,37,47 1b
0 ,1 ,2 ,3 ,4 ,5 ,6 ,7 ,8 ,9 ,e ,a ,b ,c ,h ,f
0, 1 ,2 ,3 ,4 ,5 ,6 ,7 ,8 ,9 ,* ,a ,b ,c ,d ,#
0, 1 ,2 ,3 ,4 ,5 ,6 ,7 ,8 ,9 ,10,11,12,13,14,15 16
0x40='_'
*/
key 4v4的更多相关文章
- Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作
一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...
- Dapper.Contrib:GetAsync<T> only supports an entity with a [Key] or an [ExplicitKey] property
异常处理:http://www.cnblogs.com/dunitian/p/4523006.html#dapper 原来Model是这样滴 修改后是这样滴 注意点:Model里面的Table和Key ...
- Redis百亿级Key存储方案(转)
1 需求背景 该应用场景为DMP缓存存储需求,DMP需要管理非常多的第三方id数据,其中包括各媒体cookie与自身cookie(以下统称supperid)的mapping关系,还包括了supperi ...
- 【详细教程】论android studio中如何申请百度地图新版Key中SHA1值
一.写在前面 现在越来越多的API接口要求都要求提供我们的项目SHA1值,开发版目前还要求不高,但是发布版是必定要求的.而目前定位在各大APP中也较为常见,当下主流的百度地图和高德地图都在申请的时候会 ...
- CentOS:ECDSA host key "ip地址" for has changed and you have requested strict checking(转)
原文地址:http://blog.csdn.net/ausboyue/article/details/52775281 Linux SSH命令错误:ECDSA host key "ip地址& ...
- webstorm license key
JetBrains WebStorm注册码 UserName: William License Key : ===== LICENSE BEGIN ===== 45550-12042010 00001 ...
- VS2015企业版本(安装包+key)+ .NET Reflector 9.0
Reflector9.0系下载:https://yunpan.cn/cMQj9zWbffSqy 访问密码 55eb VS2015中文企业版: http://pan.baidu.com/s/1eRIo ...
- Redis系列之key操作命令与Redis中的事务详解(六)
序言 本篇主要目的有二: 1.展示所有数据类型中key的所有操作命令,以供大家学习,查阅,更深入的挖掘redis潜力. 2.掌握redis中的事务,让你的数据完整性一致性拥有更优的保障. redis命 ...
- SQL Server-聚焦移除Bookmark Lookup、RID Lookup、Key Lookup提高SQL查询性能(六)
前言 前面几节都是讲的基础内容,本节我们讲讲索引性能优化,当对大数据进行处理时首先想到的就是索引,一旦遇到这样的问题则手忙脚乱,各种查资料,为何平常不扎实基本功呢,我们由浅入深,简短的内容,深入的理解 ...
随机推荐
- 出现Warning:Gradle version 2.10 is required. Current version is 2.8.
Warning:Gradle version 2.10 is required. Current version is 2.8. If using the gradle wrapper, try ed ...
- Python策略模式实现源码分享
1.让一个对象的某个方法可以随时改变,而不用更改对象的代码 2.对于动态类型的Python语言,不需要定义接口 3.基本的实现方法:用类作为参数传递 例如: 12_eg3.py class Movea ...
- ActionErrors 使用说明 struts1 validate 处理流程 详细教程(转)
转自(http://blog.csdn.net/wyx100/article/details/8736445). struts1 处理流程是 jsp --> ActionForm 中的A ...
- linux笔记:linux常用命令-文件处理命令
文件处理命令:touch(创建空文件) 文件处理命令:cat(显示文件内容) 文件处理命令:more(分页显示文件内容) 文件处理命令:head(显示文件前面几行) 文件处理命令:tail(显示文件后 ...
- jq三级全选全不选
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- 网络与RPC
网络与RPC 标签 : Java基础 Java为网络编程提供的java.net包封装了底层通信细节, 包含了大量的基础组件以及TCP/UDP协议的编程接口, 使得开发者可以专注于解决问题, 而不用关注 ...
- hdu----(5047)Sawtooth(大数相乘+数学推导)
Sawtooth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Su ...
- hdu----(3118)Arbiter(构造二分图)
Arbiter Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total S ...
- cf------(round)#1 C. Ancient Berland Circus(几何)
C. Ancient Berland Circus time limit per test 2 seconds memory limit per test 64 megabytes input sta ...
- Mybatis 实用
1.<delete id="removeZtreeS" parameterType="String"> DELETE FROM sys_fun WH ...