c语言发射程序,讲解c语言程序的软件

本文目录一览:

如何运用链表实现子弹连续发射 C语言 求代码

includestdio.h#includestdlib.h#includestring.hstruct people{    char name[10];    int age;    struct people * next;};int main(){    struct people * head=NULL;    struct people * prev , * current;    int flag=1;    while(flag!=0)    {        printf(“请输入学生姓名,年龄:(年龄输入0结束所有输入工作)\n”);        current=(struct people *)malloc(sizeof(struct people));        if(head==NULL)            head=current;        else            prev-next=current;        current-next=NULL;        scanf(“%s”,¤t-name);        scanf(“%d”,¤t-age);        prev=current;        flag=current-age;    }    printf(“Output:\n”);    if(head==NULL)        printf(“无资料。\n”);    else    {        current=head;        while(current-next!=NULL)        {            printf(“姓名:%s\n年龄:%d\n\n”,current-name,current-age);            current=current-next;        }    }}

51单片机驱动NRF2401的接受和发射的C语言程序

发送#include reg52.h

#includeintrins.h

// 常量定义

#define uchar unsigned char

#define uint unsigned int

#define BYTE_BIT0 0x01

#define BYTE_BIT1 0x02

#define BYTE_BIT2 0x04

#define BYTE_BIT3 0x08

#define BYTE_BIT4 0x10

#define BYTE_BIT5 0x20

#define BYTE_BIT6 0x40

#define BYTE_BIT7 0x80

//—————————位变量定义—————————————-

bdata uchar DATA_BUF; //用于ByteRead和ByteWrite 函数

#define DATA7 ((DATA_BUFBYTE_BIT7)!=0)

#define DATA0 ((DATA_BUFBYTE_BIT0)!=0)

uchar TxBuf[28]={

0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,

0x09,0x10,0x11,0x12,0x13,0x14,0x15,0x16,

0x17,0x18,0x19,0x20,0x21,0x22,0x23,0x24,

0x25,0x26,0x27,0x28,};// ——————————RF2401_Pins 对应引脚 ———————–

sbit PWR_UP = P1^3;

sbit CE = P1^2;

// sbit DR2 = P1^7; //暂时没有用到

// sbit CLK2 = P1^1;

// sbit OUT2 = P1^6;

sbit CS = P1^0;

sbit DR1 = P1^5;

sbit CLK1 = P1^4;

sbit DATA = P3^3;

//—————————————-LED显示端口—————————————————

sbit LED=P3^5;

//——————————————————————————-

unsigned char TxAddress[4]={0xcc,0xcc,0xcc,0xcc}; //发送地址

//———————nRF-Configuration-Register 配置信息 ——————————

//芯片测试用,无需修改

#define TEST_2 0x8E // MSB D143-D136

#define TEST_1 0x08 // D135~D128

#define TEST_0 0x1c // D127~D120

// 注意 DATAx_W+ADDRx_W+CRC 的值必须小于256!单个数据包的大小必须小于32字节(256位)

#define DATA2_W 0x10 //未用到–0x10=2字节 //频道2发送/接受数据长度(单位:Bit)

#define DATA1_W 0xE0 //28字节 16 位 //频道1发送/接受数据长度(单位:Bit)

//频道2接收地址 -频道2未使用

#define ADDR2_4 0x00

#define ADDR2_3 0x1c

#define ADDR2_2 0xcc

#define ADDR2_1 0xcc

#define ADDR2_0 0xcc

// 频道1接收地址 (当前模块地址) -只是用频道1

#define ADDR1_4 0x00

#define ADDR1_3 0xcc

#define ADDR1_2 0xcc

#define ADDR1_1 0xcc

#define ADDR1_0 0xcc

//接收地址位置设置–CRC设置

#define ADDR_W 0x10 //0x10 =2字节 //发送/接收地址宽度(单位:Bit)

#define CRC_L 0x1 //CRC模式 0:8位 1:16位

#define CRC_EN 0x1 //CRC校验 0:禁止 1:启用

//频道设置–发送方式设置–速率设置–频率设置

#define RX2_EN 0x0 //双频道功能 0:禁用 1:启用

#define CM 0x1 //0:Direct Mode 1: Shockburst Mode

#define RFDR_SB 0x1 //传输速率 0:250k 1: 1M (250k比1M传输距离远)

#define XO_F 0x3 //16M D12 D11 D10 确定 5种频率

#define RF_PWR 0x3 //信号发射功率—0DB

//

#define RF_CH 0x2 //Channal 频率设置Channel=2400MHz+RF_CH*1.0MHz

#define RXEN 0x0 //0:TX 1:RX

//将设置信息组合成每个字节的数据信息

#define RFconfig_Bit0 TEST_2

#define RFconfig_Bit1 TEST_1

#define RFconfig_Bit2 TEST_0

#define RFconfig_Bit3 DATA2_W

#define RFconfig_Bit4 DATA1_W

#define RFconfig_Bit5 ADDR2_4

#define RFconfig_Bit6 ADDR2_3

#define RFconfig_Bit7 ADDR2_2

#define RFconfig_Bit8 ADDR2_1

#define RFconfig_Bit9 ADDR2_0

#define RFconfig_Bit10 ADDR1_4

#define RFconfig_Bit11 ADDR1_3

#define RFconfig_Bit12 ADDR1_2

#define RFconfig_Bit13 ADDR1_1

#define RFconfig_Bit14 ADDR1_0

#define RFconfig_Bit15 (ADDR_W2|CRC_L1|CRC_EN)

#define RFconfig_Bit16 (RX2_EN7|CM6|RFDR_SB5|XO_F2|RF_PWR)

#define RFconfig_Bit17 (RF_CH1|RXEN)

//通过宏定义将18字节的寄存器参数按照各个功能分解,参照DATASHHET

uchar code nRF2401_Conf[18]=

{

RFconfig_Bit0,RFconfig_Bit1,RFconfig_Bit2,

RFconfig_Bit3,

RFconfig_Bit4,

RFconfig_Bit5,RFconfig_Bit6,RFconfig_Bit7,RFconfig_Bit8,RFconfig_Bit9,

RFconfig_Bit10,RFconfig_Bit11,RFconfig_Bit12,RFconfig_Bit13,RFconfig_Bit14,

RFconfig_Bit15,

RFconfig_Bit16,

RFconfig_Bit17

};

//——————————————函数申明——————————————

void Delay_us(uchar n);

void DoClock();

void Delay_ms(uchar n);

unsigned char Spi_ByteRead(void);

void Spi_ByteWrite(unsigned char send);

void Config2401(void);

void SetTxMode(void);

void nRF2401_TxPacket(uchar TxBuf[]);

//——————————–11.0592M晶振 n=100 868us 左右——————————-

void Delay_us(uchar n)

{

uint i;

for(i=0;in;i++);

}

//—————————————— —————————————–

void Delay_ms(uchar n)

{

unsigned int i,j,k; for(i=0;in;i++)

{

for(k=0;k5;k++)

{

for(j=0;j200;j++);

}

}

}

/*

//————————–SPI读——————————————

unsigned char Spi_ByteRead(void)

{

unsigned char i = 0;

for (i=0; i8; i++)

{

DATA_BUF = DATA_BUF 1;

CLK1 = 1;

DATA = 1; //设置为输入状态

if (DATA) //读取最高位,保存至最末尾,通过左移位完成整个字节

{

DATA_BUF |= BYTE_BIT0;

}

else

{

DATA_BUF = ~BYTE_BIT0;

}

CLK1 = 0;

}

return DATA_BUF;

}*/

//———————————-SPI写—————————————–

void Spi_ByteWrite(unsigned char send)

{

unsigned char i; DATA_BUF = send; CLK1 = 0; for (i=0; i8; i++)

{

if (DATA7) //总是发送最高位

{

DATA = 1;

}

else

{

DATA = 0;

}

CLK1 = 1;

DATA_BUF = DATA_BUF 1;

CLK1 = 0;

}

}

//—————————–配置2401——————————————–

void Config2401(void)

{

uint i;

uchar variable1;

PWR_UP=1; //上电

CE=0;

CS=1; //使RF2401进入配置方式

Delay_ms(3); //从上电到进入配置模式需要3ms的延时(最少)

for(i=0;i18;i++) //输入3个测试字节15个配置字节共 18Byte

{

variable1=nRF2401_Conf[i];

Spi_ByteWrite(variable1);

}

CS=0; //Disable CS —–standby mode

DATA=0;

Delay_us(100);

}

//——————————–设置为发送模式 —————————-

void SetTxMode(void)

{

//——————————-设置为配置模式———————————-

PWR_UP=1; //上电

CE=0;

CS=1; //进入配置模式

Delay_us(100);

DATA=0; //配置寄存器0字节RXEN 设置为0: 发送模式

CLK1=1;

CLK1=0;

//—————————-设置为 Activemodes(TX)——————————

CS=0;

CE=1; //set standby mode

Delay_us(100);

}

//——————————–nRF 数据发送函数——————————–

void nRF2401_TxPacket()

{

int i;

uchar variable2;

CE=1;

for(i=0;i2;i++) //写入接受地址(按字节对齐)

{

variable2=TxAddress[i];

Spi_ByteWrite(variable2);

}

for(i=0;i(28);i++) //写入接受地址(按字节对齐)

{

variable2=TxBuf[i];

Spi_ByteWrite(variable2);

}

CE=0; //CE配置低使发送有效

Delay_us(100); //时钟信号高电平有效

}

//————————————主函数—————————————

main()

{

Config2401();

while(1)

{

nRF2401_TxPacket();

SetTxMode();

LED=0; Delay_ms(10);LED=1; Delay_ms(10);

}

}

单片机程序火箭发射,倒计时和推送都有,用C语言编写

#include iostream

#include vector

#include algorithm

using namespace std;

int is_right(int a[],int k)

{

int jian_ge=a[1]-a[0];

int count_num=0;

for(int i=0; ia href=”;tn=44039180_cprfenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1d9nhndrAnLnAnkmHf3rH0d0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EnH6vnW0vrHcLnjR1nWmYnj6vPs” target=”_blank” class=”baidu-highlight”k-1/a; i++)

{

if(a[i+1]-a[i]==jian_ge)

{

count_num++;

}

}

return count_num==a href=”;tn=44039180_cprfenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1d9nhndrAnLnAnkmHf3rH0d0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EnH6vnW0vrHcLnjR1nWmYnj6vPs” target=”_blank” class=”baidu-highlight”k-1/a?true:false;

}

int main()

{

int i;

cini;

vector char result;

vector char :: iterator it;

for(int j=1; j=i; j++)

{

int k;

cink;

int a[k];

for(int m=0; mk; m++)

{

cina[m];

}

if(is_right(a,k)==1)

{

result.push_back(‘Y’);

}

else

{

result.push_back(‘N’);

}

}

// reverse(result.begin(),result.end());

for(it=result.begin(); it!=result.end(); it++)

{

cout*itendl;

}

return 0;

}

用C语言编写的红外发射与接收程序

给你一段430单片机遥控器解码的程序吧,也就是接收部分

毕竟世界太现实只能这么帮你

#ifndef _IR_

#define _IR_

char t0,t1,t2;

uchar IR;

void DelayIR()

{

uint i=130;

while(i–);

}

void init_port2(void)

{

P2DIR=~BIT0;

P2SEL=~BIT0;

P2IES|=BIT0;

P2IE|=BIT0;

}

#pragma vector=PORT2_VECTOR

__interrupt void PORT2_ISR(void)

{

char CounterIR;

P2IES=~BIT0;

if(P2IFGBIT0)

{

P2IFG=~BIT0;

}

CounterIR=0;

while(!(P2INBIT0))

{

DelayIR();

CounterIR++;

}

if(CounterIR85)

{

if(CounterIR95)

{

t1++;

for(char k=0;k17;k++)

{

CounterIR=0;

while((P2INBIT0)(CounterIR50))

{

DelayIR();

CounterIR++;

}

CounterIR=0;

while((!(P2INBIT0))(CounterIR10))

{

DelayIR();

CounterIR++;

}

}

for(char j=0;j8;j++)

{

CounterIR=0;

while((P2INBIT0)(CounterIR25))

{

DelayIR();

CounterIR++;

}

IR=1;

if(CounterIR11)

IR|=BIT0;

CounterIR=0;

while((!(P2INBIT0))(CounterIR10))

{

DelayIR();

CounterIR++;

}

}

if((IR!=0xff)(IR!=0x00))

{

if(!(flagdataflag))

{

if(IR==0x22)

{

flag|=runflag;

}

else

{

Tar[0]=Tar[1];

Tar[1]=Tar[2];

Tar[2]=Tar[3];

Tar[3]=Tar[4];

switch (IR)

{

//case 0x22 : flag|=runflag;break;

case 0x68 : Tar[4]=0;flag|=dataflag;break;

case 0x30 : Tar[4]=1;flag|=dataflag;break;

case 0x18 : Tar[4]=2;flag|=dataflag;t2++;break;

case 0x7a : Tar[4]=3;flag|=dataflag;break;

case 0x10 : Tar[4]=4;flag|=dataflag;break;

case 0x38 : Tar[4]=5;flag|=dataflag;break;

case 0x5a : Tar[4]=6;flag|=dataflag;break;

case 0x42 : Tar[4]=7;flag|=dataflag;break;

case 0x4a : Tar[4]=8;flag|=dataflag;break;

case 0x52 : Tar[4]=9;flag|=dataflag;break;

default : break;

}

}

}

}

IR=0;

}

}

for(int m=0;m250;m++)

DelayIR();

P2IES|=BIT0;

}

#endif

请采纳。

求一份基于51单片机4X4矩阵键盘红外发射C语言程序,最好附原理图哦!!

#include “reg52.h”

sbit ir=P2^0;//红外发射管控制脚,使用24M晶振

sbit led = P2^1;

sbit ka=P1^0;

sbit kb=P1^1;

sbit kc=P1^2;

sbit kd=P1^3;

unsigned int count, set_count; //中断计数,设定中断次数

bit irflag,keyflag; //红外发送标志位,按键标志位

unsigned char irsys[]={0x00,0xff};//16位用户码

unsigned char irdata,ircode; //发送的红外数据

//—————————————————————————

void delay(unsigned int a)//延时约1ms,晶振24M ,此处延时不需很精确

{

unsigned char i;

while(–a!=0)

for(i=300;i0;i–); //若是12M晶振i=125

}

//—————————————————————————

void keyscan() // 按键扫描

{

if(ka==0)

{ delay(5);

while(!ka);

keyflag=1;irdata=0x0a;

} //a键按下,则发射数据0x0a

if(kb==0)

{ delay(5);

while(!kb);

keyflag=1;irdata=0x0b;

} //a键按下,则发射数据0x0a

if(kc==0)

{ delay(5);

while(!kc);

keyflag=1;irdata=0x0c;

} //a键按下,则发射数据0x0a

if(kd==0)

{ delay(5);

while(!kd);

keyflag=1;irdata=0x0d;

} //a键按下,则发射数据0x0a

}

//—————————————————————————

void ir_sendbyte() //红外发送一个字节数据

{

unsigned char i;

for(i=0;i8;i++) //发送8位数据

{

set_count=43;//35; //发送编码中的0.56ms高电平 (//后为12M晶振下的数值)

irflag=1; //启动红外发射二极管发射

count=0; //中断计数先清0

TR0=1; //开启定时器0

while(countset_count); //等待发送完

TR0=0; //关闭定时器0

if(ircode0x01) set_count=130;//130; //判断红外编码最低位,若为1则1.69ms的低电平 (//后为12M晶振下的数值)

else set_count=43;//35; //为0则0.565ms的低电平 (//后为12M晶振下的数值)

irflag=0; //低电平则不发射

count=0; //中断计数清0

TR0=1; //开启定时器0

while(countset_count); //等待发送完

TR0=0; //关闭定时器0

ircode=ircode1; //将数据右移,即从低位到高位发送

}

}

//—————————————————————————

void ir_send() //发送红外数据

{

set_count=692;//672; //发送编码中的引导码(9ms高电平+4.5ms低电平) (//后为12M晶振下的数值) tc9012

irflag=1; //启动红外发射二极管发射

count=0; //中断计数清0

TR0=1;

while(countset_count);

TR0=0;

set_count=346;//336; //发送编码中的4.5ms低电平(//后为12M晶振下的数值)

irflag=0; //低电平则不发射

count=0;

TR0=1;

while(countset_count); //等待发送完

TR0=0;

ircode=irsys[0]; //发送16位用户码的前1-8位

ir_sendbyte();

ircode=irsys[1]; //发送16位用户码的前9-16位

ir_sendbyte();

ircode=irdata; //发送8位数据码

ir_sendbyte();

ircode=~irdata; //发送8位数据反码

ir_sendbyte();

set_count=43;//35; //发送编码中的0.56ms高电平 (//后为12M晶振下的数值)

irflag=1;

count=0;

TR0=1;

while(countset_count);

TR0=0;

ir=1;

delay(23); //延时23ms(编码中的23ms低电平)

set_count=692;//670; //发送编码中的引导码(9ms高电平+4.5ms低电平) (//后为12M晶振下的数值)

irflag=1;

count=0;

TR0=1;

while(countset_count);

TR0=0;

set_count=346;//336; //发送编码中的4.5ms低电平(//后为12M晶振下的数值)

irflag=0;

count=0;

TR0=1;

while(countset_count);

TR0=0;

set_count=43;//35; //发送编码中的0.56ms高电平 (//后为12M晶振下的数值)

irflag=1;

count=0;

TR0=1;

while(countset_count);

TR0=0;

ir=1; //发射完了关闭红外发射二极管

}

//—————————————————————————

void timer0_init() //定时器初始化

{

EA=1;

TMOD=0x02; //定时0 8位自动重装模式

ET0=1;

TH0=0xe6;//0xf3; //定时13us,38K红外矩形波,晶振24M (//后为12M晶振下的数值)

TL0=0xe6;

}

//—————————————————————————

void main()

{

timer0_init(); //定时0初始化

count=0; //中断计数先清0

irflag=0; //红外发射标志先置0

while(1)

{

keyscan(); //键值扫描

if(keyflag) //若有按键按下

{

led = 0;

delay(10);

ir_send(); //发送红外编码

delay(500);

keyflag=0; //按键标志清零

delay(100);

}

else

{

led = 1;

}

}

}

//—————————————————————————

void timer0() interrupt 1 //定时器0中断

{

count++;

if(irflag==1) ir=~ir; //有发射标志,则发射38khz的矩形波

else ir=1; //否则不发射,即相当于发射编码中的低电平

}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/186525.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-27 05:47
下一篇 2024-11-27 05:47

相关推荐

  • python强行终止程序快捷键

    本文将从多个方面对python强行终止程序快捷键进行详细阐述,并提供相应代码示例。 一、Ctrl+C快捷键 Ctrl+C快捷键是在终端中经常用来强行终止运行的程序。当你在终端中运行…

    编程 2025-04-29
  • Python程序需要编译才能执行

    Python 被广泛应用于数据分析、人工智能、科学计算等领域,它的灵活性和简单易学的性质使得越来越多的人喜欢使用 Python 进行编程。然而,在 Python 中程序执行的方式不…

    编程 2025-04-29
  • Python脚本控制其他软件

    Python作为一种简单易学、功能强大的脚本语言,具有广泛的应用领域,在自动化测试、Web开发、数据挖掘等领域都得到了广泛的应用。其中,Python脚本控制其他软件也是Python…

    编程 2025-04-29
  • Python程序文件的拓展

    Python是一门功能丰富、易于学习、可读性高的编程语言。Python程序文件通常以.py为文件拓展名,被广泛应用于各种领域,包括Web开发、机器学习、科学计算等。为了更好地发挥P…

    编程 2025-04-29
  • AES加密解密算法的C语言实现

    AES(Advanced Encryption Standard)是一种对称加密算法,可用于对数据进行加密和解密。在本篇文章中,我们将介绍C语言中如何实现AES算法,并对实现过程进…

    编程 2025-04-29
  • 量化交易软件哪个好?

    量化交易软件是为量化交易而设计的工具,能够用程序化方法对市场数据进行分析和交易决策。那么,哪个量化交易软件最好呢?下面从几个方面进行详细阐述。 一、交易功能 交易功能是量化交易软件…

    编程 2025-04-29
  • 学习Python对学习C语言有帮助吗?

    Python和C语言是两种非常受欢迎的编程语言,在程序开发中都扮演着非常重要的角色。那么,学习Python对学习C语言有帮助吗?答案是肯定的。在本文中,我们将从多个角度探讨Pyth…

    编程 2025-04-29
  • Python购物车程序

    Python购物车程序是一款基于Python编程语言开发的程序,可以实现购物车的相关功能,包括商品的添加、购买、删除、统计等。 一、添加商品 添加商品是购物车程序的基础功能之一,用…

    编程 2025-04-29
  • 爬虫是一种程序

    爬虫是一种程序,用于自动获取互联网上的信息。本文将从如下多个方面对爬虫的意义、运行方式、应用场景和技术要点等进行详细的阐述。 一、爬虫的意义 1、获取信息:爬虫可以自动获取互联网上…

    编程 2025-04-29
  • Python被称为胶水语言

    Python作为一种跨平台的解释性高级语言,最大的特点是被称为”胶水语言”。 一、简单易学 Python的语法简单易学,更加人性化,这使得它成为了初学者的入…

    编程 2025-04-29

发表回复

登录后才能评论