#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. 关于vp8,vp8与264比较总结

    1 Other Codecs l MSN 使用的video codec “x-rtvc1”,09之前的版本使用的ML20.参考网址: http://www.amsn-project.net/forum ...

  2. 队列 - 从零开始实现by C++

    参考链接:数据结构探险-队列篇 数据结构太重要了,不学好是没法进行软件开发的. C++写数据结构基本套路:一个.h文件写该数据结构类的接口:一个.cpp文件写接口的具体实现:一个main.cpp用于测 ...

  3. JAVA多线程和并发基础面试问答

    转载: JAVA多线程和并发基础面试问答 多线程和并发问题是Java技术面试中面试官比较喜欢问的问题之一.在这里,从面试的角度列出了大部分重要的问题,但是你仍然应该牢固的掌握Java多线程基础知识来对 ...

  4. 委托(C# 编程指南)

    原文地址:https://msdn.microsoft.com/zh-cn/library/ms173171.aspx delegate 是表示对具有特定参数列表和返回类型的方法的引用的类型. 在实例 ...

  5. 浅谈线程池(中):独立线程池的作用及IO线程池

    原文地址:http://blog.zhaojie.me/2009/07/thread-pool-2-dedicate-pool-and-io-pool.html 在上一篇文章中,我们简单讨论了线程池的 ...

  6. python 练习 18

    #!/usr/bin/python # -*- coding: UTF-8 -*- import time print time.strftime('%Y-%m-%d %H:%M:%S',time.l ...

  7. from __future__ import absolute_import

    from __future__ import absolute_import 这样以后:局部的包将不能覆盖全局的包, 本地的包必须使用相对引用了. 例: from celery import Cele ...

  8. SAP连接HANA数据库

    既然都用HANA了,为什么还要在SAP端,连接HANA数据库,做数据库处理..... 因为HANA数据库,没个用户在STADIO上建的数据库表...只能这个用户使用,而做Universe 设计的时候, ...

  9. uva 11624(bfs)

    11624 - Fire! Time limit: 1.000 seconds Joe works in a maze. Unfortunately, portions of the maze hav ...

  10. 《Learning Play! Framework 2》学习笔记——案例研究1(Templating System)

    注解: 这是对<Learning Play! Framework 2>第三章的学习 本章是一个显示聊天记录的项目,只有一个页面,可以自动对聊天记录进行排序.分组和显示,并整合使用了less ...