wiringpi库的应用 -- sg90 定时器 oled

2024-04-20 03:44

本文主要是介绍wiringpi库的应用 -- sg90 定时器 oled,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

sg 90舵机:  

接线: 
VCC  --    红
GND --    地
信号线  -- 黄 -- pwm

定时器: 

 
 先玩定时器: sg90 需要的pwm波需要定时器输出,so我们得先来玩一下定时器

分析:实现定时器,通过itimerval结构体以及函数setitimer产生的信号,系统随之使用signal信号处理函数来处理产生的定时信号。从而实现定时器。


先看itimerval的结构体


setitimer()将value指向的结构体设为计时器的当前值,如果ovalue不是NULL,将返回计时器原有值。

struct itimerval
{
/* Value to put into `it_value' when the timer expires. */
struct timeval it_interval;
/* Time to the next timer expiration. */
struct timeval it_value;
};
 
it_interval:计时器的初始值,一般基于这个初始值来加或者来,看控制函数的参数配置
it_value:程序跑到这之后,多久启动定时器

setitimer()

int setitimer (__itimer_which_t __which,
const struct itimerval *__restrict __new,
struct itimerval *__restrict __old)
setitimer()将value指向的结构体设为计时器的当前值,如果ovalue不是NULL,将返回计时器原有值。
which:三种类型
ITIMER_REAL //数值为0,计时器的值实时递减,发送的信号是SIGALRM
ITIMER_VIRTUAL //数值为1,进程执行时递减计时器的值,发送的信号是SIGVTALRM。
ITIMER_PROF //数值为2,进程和系统执行时都递减计时器的值,发送的信号是SIGPROF。
很明显,这边需要捕获对应的信号进行逻辑相关处理 signal(SIGALRM,signal_handler);

返回说明:
成功执行时,返回0。失败返回-1

//perror 在stdlib.h中

=============================================


case: 实现定时器每隔一秒打印字符串


#include<stdio.h>
#include<sys/time.h>
#include<stdlib.h>
#include<signal.h>

static int i;
void signal_handler(int signum)
{
    i++;
    if(i==2000){//0.5ms *2000=1000ms =1s
        puts("mxjun");
        i=0;
    }

}


int main()
{
    struct itimerval itv;


    //设定定时器时间
    itv.it_interval.tv_sec=0;
    itv.it_interval.tv_usec=500;

    //设定开始生效时间,启动定时器的时间
    itv.it_value.tv_sec=1;
    itv.it_value.tv_usec=0;// 500us = 0.5ms

    //设定定时的方式 -- 一般ITIMER_REAL --数值为0,计时器的值实时递减,发送的信号是SIGALRM
    if(-1 ==setitimer(ITIMER_REAL,&itv,NULL)){
        perror("error");
        exit(-1);
    }

    //信号处理 -- 收到上面发的SIGALRM信号,用signal_handler去处理

    signal(SIGALRM,signal_handler);
    while(1);

    return 0;
}

============================================

 学会定时器的是使用后就能很快实现sg90了

 


sg90 实例:  输入一个数,让舵机旋转指定角度


#include<stdio.h>
#include<sys/time.h>
#include<stdlib.h>
#include<signal.h>
#include<wiringPi.h>

#define SG90 0  
int jd;

static int i;

// 在单片机中我们使用定时器中断来,处理,这里我们信号处理, 来绘制PWM波形
void signal_handler(int signum)
{

    if(i<=jd)
        digitalWrite(SG90,HIGH);
    else
        digitalWrite(SG90,LOW);
    if(i==40){//  20 ms
        i=0;
    }
    i++;

}


int main()
{
    struct itimerval itv;
    wiringPiSetup(); 
    pinMode(SG90,OUTPUT);
    jd=0;
    //设定定时时间
    itv.it_interval.tv_sec=0;
    itv.it_interval.tv_usec=500;

    //设定开始生效时间,启动定时器时间
    itv.it_value.tv_sec=1;
    itv.it_value.tv_usec=0;// 500us = 0.5ms

    //设定定时方式
    if(-1 ==setitimer(ITIMER_REAL,&itv,NULL)){// 这个递减宏对应返回的信号就是SIGALRM
        perror("error");
        exit(-1);
    }

    //信号处理

    signal(SIGALRM,signal_handler);
    while(1)
    {
      printf("input jd:1-0  2-45 3-90 4-135\n");
      scanf("%d",&jd);
    
    }

    return 0;
}

olde 

不了解诶olde的朋友请跳转:IIC协议--OLED-CSDN博客

/*
 * Copyright (c) 2015, Vladimir Komendantskiy
 * MIT License
 *
 * SSD1306 demo of block and font drawing.
 */

//
// fixed for OrangePiZero by HypHop
//

#include <errno.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <stdint.h>

#include "oled.h"
#include "font.h"

int oled_show(struct display_info *disp) {
    int i;
    char buf[100];

    oled_putstrto(disp, 0, 9+1, "Welcome to My HomeAssitant");
    disp->font = font1;

    oled_putstrto(disp, 0, 20, "  ---Mr.MXJ Handsome--");
    disp->font = font1;

    oled_send_buffer(disp);


return 0;
}

void show_error(int err, int add) {
    //const gchar* errmsg;
    //errmsg = g_strerror(errno);
    printf("\nERROR: %i, %i\n\n", err, add);
    //printf("\nERROR\n");
}

void show_usage(char *progname) {
    printf("\nUsage:\n%s <I2C bus device node >\n", progname);
}

int main(int argc, char **argv) {
    int e;
    char filename[32];
    struct display_info disp;

    if (argc < 2) {
        show_usage(argv[0]);
        
        return -1;
    }

    memset(&disp, 0, sizeof(disp));
    sprintf(filename, "%s", argv[1]);
    disp.address = OLED_I2C_ADDR;
    disp.font = font2;

    e = oled_open(&disp, filename);
    e = oled_init(&disp);
    oled_show(&disp);


    return 0;
}
 

这篇关于wiringpi库的应用 -- sg90 定时器 oled的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/919213

相关文章

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象

Go信号处理如何优雅地关闭你的应用

《Go信号处理如何优雅地关闭你的应用》Go中的优雅关闭机制使得在应用程序接收到终止信号时,能够进行平滑的资源清理,通过使用context来管理goroutine的生命周期,结合signal... 目录1. 什么是信号处理?2. 如何优雅地关闭 Go 应用?3. 代码实现3.1 基本的信号捕获和优雅关闭3.2

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取