#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的更多相关文章

  1. Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  2. 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 ...

  3. Redis百亿级Key存储方案(转)

    1 需求背景 该应用场景为DMP缓存存储需求,DMP需要管理非常多的第三方id数据,其中包括各媒体cookie与自身cookie(以下统称supperid)的mapping关系,还包括了supperi ...

  4. 【详细教程】论android studio中如何申请百度地图新版Key中SHA1值

    一.写在前面 现在越来越多的API接口要求都要求提供我们的项目SHA1值,开发版目前还要求不高,但是发布版是必定要求的.而目前定位在各大APP中也较为常见,当下主流的百度地图和高德地图都在申请的时候会 ...

  5. 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地址& ...

  6. webstorm license key

    JetBrains WebStorm注册码 UserName: William License Key : ===== LICENSE BEGIN ===== 45550-12042010 00001 ...

  7. VS2015企业版本(安装包+key)+ .NET Reflector 9.0

    Reflector9.0系下载:https://yunpan.cn/cMQj9zWbffSqy  访问密码 55eb VS2015中文企业版: http://pan.baidu.com/s/1eRIo ...

  8. Redis系列之key操作命令与Redis中的事务详解(六)

    序言 本篇主要目的有二: 1.展示所有数据类型中key的所有操作命令,以供大家学习,查阅,更深入的挖掘redis潜力. 2.掌握redis中的事务,让你的数据完整性一致性拥有更优的保障. redis命 ...

  9. SQL Server-聚焦移除Bookmark Lookup、RID Lookup、Key Lookup提高SQL查询性能(六)

    前言 前面几节都是讲的基础内容,本节我们讲讲索引性能优化,当对大数据进行处理时首先想到的就是索引,一旦遇到这样的问题则手忙脚乱,各种查资料,为何平常不扎实基本功呢,我们由浅入深,简短的内容,深入的理解 ...

随机推荐

  1. 基于SourceTree 下的 Git Flow 模型

    基于SourceTree 下的 Git Flow 模型 1. sourceTree  是一个开源的git 图形管理工具,可下载mac版本,windows版本 2. Git Flow 是一套使用Git进 ...

  2. java 内部类1

    内部类: 常用的情景:一个类要经常访问另一个类的成员. 举个例子: class人 { 血,氧气... class 心脏{...} } 内部类的优势: 成员内类,作为外部类的成员,可以方便随意的访问外部 ...

  3. shader学习路线

    http://www.jianshu.com/p/7b9498e58659 http://blog.csdn.net/candycat1992/article/details/37882765

  4. arithmetic

    字典序算法 http://www.cnblogs.com/darklights/p/5285598.html 字典排序(lexicographical order)是一种对于随机变量形成序列的排序方法 ...

  5. jmeter 远程测试

    如果你的JMeter客户机不能进行属性,来模拟 足够的用户强调您的服务器或在网络水平是有限的,存在一个选项来控制多个远程JMeter 引擎从一个JMeter客户机. 通过运行JMeter远程,你可以复 ...

  6. kmeans算法原理以及实践操作(多种k值确定以及如何选取初始点方法)

    kmeans一般在数据分析前期使用,选取适当的k,将数据聚类后,然后研究不同聚类下数据的特点. 算法原理: (1) 随机选取k个中心点: (2) 在第j次迭代中,对于每个样本点,选取最近的中心点,归为 ...

  7. 默认选择radio的第一个

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. cd命令进入D盘

    CD命令是更改目录命令如果要进入D盘 不用这个命令 直接输入 D: 回车 即可要是你非要使用CD命令那要加参数/DCD D:系统只是认为你想在系统中记忆一下D盘所以还是返回原先目录例:D盘下有一个目录 ...

  9. iOS应用架构现状分析

    iOS从2007年诞生至今已有近10年的历史,10年的时间对iOS技术圈来说足够产生相当可观的沉淀,尤其这几年的技术分享氛围无论国内国外都显得异常活跃.本文就iOS架构这一主题,结合开发圈里讨论较多的 ...

  10. Android画一条横线

    <View android:layout_width="match_parent" android:layout_height="1px" android ...