在单片机系统中, 如果并行口的IO资源不够,而串行口又没有其他的作用, 那么我们可以用74LS164来扩展并行IO口,节约单片机资源。

      74LS164是一个串行输入并行输出的移位寄存器。并带有清除端。
      其中: Q0—Q7 并行输出端 。 A,B串行输入端。 MR 清除端, 为0时,输出清零。 CP 时钟输入端。

74LS164引脚定义:

74LS164逻辑表:

相关原理:

 

74LS164.c

---------------------------------------------------------------------------------------------------------------------------------------------

 

#include "stm32f10x.h"
#include "stm32f10x_rcc.h"
#include "stm32f10x_gpio.h" #include "74LS164.h"
/* 延时模块82615468 sp-320-12
* */
static void delay(u32 t)
{
u32 i;
while(t--)
for (i = 0; i < 1; i++);
} void Ls164Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(LS164_CLK_GPIO_CLK | LS164_DATA_GPIO_CLK, ENABLE); GPIO_InitStructure.GPIO_Pin = LS164_CLK_PIN;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(LS164_CLK_GPIO, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = LS164_DATA_PIN;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(LS164_DATA_GPIO, &GPIO_InitStructure);
LS164_CLK_H();
LS164_DATA_H(); }
void Ls164Send(u8 data)
{
u8 k;
for(k = 8; k > 0; k--)
{
LS164_CLK_L();
delay(1);
if(data & 0x01)
LS164_DATA_H();
else
LS164_DATA_L();
LS164_CLK_H();
delay(1);
data >>= 1;
}
} /* _____________________________________________________________
164SendTime1 Line0 0bit | |
Line1 1bit | |
Line2 2bit | |
Line3 3bit | |
Line4 4bit | |
Line5 5bit | |
Line6 6bit | |
Line7 7bit | |
164SendTime0 Line8 0bit | |
Line9 1bit | |
Line10 2bit | |
Line11 3bit | |
Line12 4bit | |
Line13 5bit | |
Line14 6bit | |
Line15 7bit |_____________________________________________________________|
*/ void LedLineOut(u8 LineN)
{
u16 LineData;
LineN %= 16; //行取值范围
LineData = ~(0x0001 << LineN); //取反低电平有效
Ls164Send(LineData & 0xff); //第1片164(Line0~7)
Ls164Send(LineData >> 8); //第0片164(Line8~15)
} //end of file
	

74LS164.h

---------------------------------------------------------------------------------------------------------------------------------------------------------------

 

#ifndef __74LS164_H__
#define __74LS164_H__ #define LS164_CLK_PIN GPIO_Pin_4
#define LS164_CLK_GPIO GPIOA
#define LS164_CLK_GPIO_CLK RCC_APB2Periph_GPIOA
#define LS164_CLK_H() GPIOA->BSRR = LS164_CLK_PIN
#define LS164_CLK_L() GPIOA->BRR = LS164_CLK_PIN #define LS164_DATA_PIN GPIO_Pin_5
#define LS164_DATA_GPIO GPIOA
#define LS164_DATA_GPIO_CLK RCC_APB2Periph_GPIOA
#define LS164_DATA_H() GPIOA->BSRR = LS164_DATA_PIN
#define LS164_DATA_L() GPIOA->BRR = LS164_DATA_PIN void Ls164Send(u8 data);
void Ls164Init(void);
void LedLineOut(u8 LineN);
#endif

 

 

74LS164 for stm32 源码下载

74LS164 for stm32 源码下载的更多相关文章

  1. STM32例程之USB HID双向数据传输(源码下载)【转】

    程序功能 将STM32的USB枚举为HID设备. STM32使用3个端点,端点0用于枚举用,端点1和2用于数据的发送和接收. 端点长度为64,也就是单次最多可以传输64个字节数据. STM32获取上位 ...

  2. C# ini文件操作【源码下载】

    介绍C#如何对ini文件进行读写操作,C#可以通过调用[kernel32.dll]文件中的 WritePrivateProfileString()和GetPrivateProfileString()函 ...

  3. C# Excel导入、导出【源码下载】

    本篇主要介绍C#的Excel导入.导出. 目录 1. 介绍:描述第三方类库NPOI以及Excel结构 2. Excel导入:介绍C#如何调用NPOI进行Excel导入,包含:流程图.NOPI以及C#代 ...

  4. C# 条形码操作【源码下载】

    本篇介绍通过C#生成和读取一维码.二维码的操作. 目录 1. 介绍:介绍条形码.条形码的分类以及ZXing.Net类库. 2. 一维码操作:包含对一维码的生成.读取操作. 3. 二维码操作:包含对二维 ...

  5. DataGridView绑定源码下载

    效果图: 源码下载:http://hovertree.com/h/bjaf/bbot18bj.htm 上面源码不包含数据库的查询,需要获取数据库数据的话,请看这个的源码: http://hovertr ...

  6. Web 开发中很实用的10个效果【附源码下载】

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...

  7. Android 源码下载方法(Git 方式clone)

    Android源码对于Android开发者来说,迟早有一天你会用到的,所以就记录一下,分享给读者,希望对读者有用 这里需要使用到Git相关知识,不清楚的可以先阅读,了解的可以跳过 Git-Tortoi ...

  8. yate: windows下源码下载,配置,编译

    源码下载:使用svn下载checkout:http://voip.null.ro/svn/yate/trunk 配置:(本人使用的是vs2008,故下载的qt工具都是对应2008) 1. 下载并安装q ...

  9. Android斗地主棋牌游戏牌桌实现源码下载

    本次给大家分享下Android斗地主棋牌游戏牌桌实现源码下载如下: 为了节约内存资源,每张扑克牌都是剪切形成的,当然这也是当前编程的主流方法. 1.主Activity package com.biso ...

随机推荐

  1. ANDROID_MARS学习笔记_S01_012_SeekBar

    1.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns: ...

  2. James搭建邮件服务器

    来源:http://chenfengcn.iteye.com/blog/356874   1 关于James与Javamail Apache James(Java Apache Mail Enterp ...

  3. 【转】奇异值分解(We Recommend a Singular Value Decomposition)

    文章转自:奇异值分解(We Recommend a Singular Value Decomposition) 文章写的浅显易懂,很有意思.但是没找到转载方式,所以复制了过来.一个是备忘,一个是分享给 ...

  4. 关于捕获键盘信息的processDialogkey方法2--具体应用

    自定义控件里的keydown方法无法捕获所有的按键消息的处理方法1(自定义控件里的keydown方法无法获取的键值如上下左右键等) 处理办法具体如下: 1.首先在自定义控件UserControl1中重 ...

  5. window.addEventListener来解决让一个js事件执行多个函数

    可能你也碰到过这种情况,就是在js的代码中用了window.onload后,可能会影响到body中的onload事件.这时就要用window.attachEvent和window.addEventLi ...

  6. poj 1416 Shredding Company( dfs )

    我的dfs真的好虚啊……,又是看的别人的博客做的 题目== 题目:http://poj.org/problem?id=1416 题意:给你两个数n,m;n表示最大数,m则是需要切割的数. 切割m,使得 ...

  7. [swustoj 1092] 二分查找的最大次数

    二分查找的最大次数(1092) 问题描述 这里是一个在排序好的数组A(从小到大)中查找整数X的函数,返回值是查找次数. int binarySearch(inta[],int n,int x)//数组 ...

  8. linux SPI bus demo hacking

    /********************************************************************** * linux SPI bus demo hacking ...

  9. 【聚类算法】谱聚类(Spectral Clustering)

    目录: 1.问题描述 2.问题转化 3.划分准则 4.总结 1.问题描述 谱聚类(Spectral Clustering, SC)是一种基于图论的聚类方法——将带权无向图划分为两个或两个以上的最优子图 ...

  10. Java [leetcode 38]Count and Say

    题目描述: The count-and-say sequence is the sequence of integers beginning as follows: 1, 11, 21, 1211, ...