qt 如何制作动态库插件

首先

首先第一点要确定我们的接口是固定的,也就是要确定

#ifndef RTSPPLUGIN_H
#define RTSPPLUGIN_H
#include "rtspplugin_global.h"
typedef void (*func_callback)(uint8_t* data,int len,uint32_t ssrc,uint32_t ts,const char* ipfrom,uint16_t fport);
extern "C"
{
RTSPPLUGIN_EXPORT const char* func_name();
RTSPPLUGIN_EXPORT int func_no();
//类型,接入类型?
RTSPPLUGIN_EXPORT int func_access();
RTSPPLUGIN_EXPORT void* create(const char* ip, uint16_t port, func_callback callback);
RTSPPLUGIN_EXPORT int  start(void *server);
RTSPPLUGIN_EXPORT void stop(void* server);
}
#endif // RTSPPLUGIN_H

使用extern “C” 来保持接口能被正确的找到函数名

rtspplugin_global.h 文件定义宏

#include <QtCore/qglobal.h>#if defined(RTSPPLUGIN_LIBRARY)
#  define RTSPPLUGIN_EXPORT Q_DECL_EXPORT
#else
#  define RTSPPLUGIN_EXPORT Q_DECL_IMPORT
#endif

文件实现如下,需要定义一个结构体,将需要保存的数据结构都放在里面

#include "rtspplugin.h"
#include <string>
extern "C"
{
#include <libavcodec/avcodec.h>
#include <libavformat/avformat.h>
#include <libavutil/pixdesc.h>
#include <libavutil/hwcontext.h>
#include <libavutil/opt.h>
#include <libavutil/avassert.h>
#include <libavutil/imgutils.h>
#include <libswscale/swscale.h>}typedef struct rtsplugin
{struct SwsContext* img_convert_ctx = NULL;AVFormatContext* input_ctx = NULL;int video_stream, ret;AVStream* video = NULL;//AVCodecContext* decoder_ctx = NULL;//AVCodec* decoder = NULL;AVPacket packet;enum AVHWDeviceType type;std::string url;
}rtsplugin;
const char* func_name()
{return "rtspclient";
}
int func_no()
{return 10;
}
void* create(const char* ip, uint16_t port, func_callback callback)
{rtsplugin* pi = new rtsplugin();return pi;
}
int  start(void *client)
{return 0;
}
void stop(void* client)
{
}

qt的pro文件如下

QT -= gui
#QT += core gui widgets
TEMPLATE = lib
DEFINES += RTSPPLUGIN_LIBRARYCONFIG += c++11# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS
INCLUDEPATH += ../VT_qt/win64/
DESTDIR = ../
# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0SOURCES += \rtspplugin.cppHEADERS += \rtspplugin_global.h \rtspplugin.hwin32{DEFINES += WIN32_LEAN_AND_MEANLIBS += -L../VT_qt/win64/DESTDIR = ../VT_qt/bin64/## FFmpegLIBS += -lavformat      \-lavdevice      \-lavcodec       \-lswresample    \-lswscale       \-lavutil        \-lopencv_world450d}# Default rules for deployment.
unix {target.path = /usr/lib
}
!isEmpty(target.path): INSTALLS += target

编译完成,正确生成 动态库
在这里插入图片描述

调用

生成exe文件
pro文件如下

TEMPLATE = app
CONFIG += console c++11
CONFIG -= app_bundlewin32{DEFINES += WIN32_LEAN_AND_MEANDESTDIR = ../VT_qt/bin64/
}#CONFIG -= qt
QT       += coreSOURCES += \main.cpp
#include <QCoreApplication>
#include <QLibrary>
#include <QDebug>using namespace std;
typedef void(*func_callback)(uint8_t* data,int len,uint32_t ssrc,uint32_t ts,const char* ipfrom,uint16_t fport);typedef  const char* (*func_name)();
typedef int (*func_no)();
typedef int (*func_access)();
//接入型插件,必须create, start stop
typedef void* (*create)(const char* ip, uint16_t port, func_callback callback);
typedef int (*start)(void *server);
typedef void (*stop)(void* server);
int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);QString library_path = QCoreApplication::applicationDirPath() + "/rtspplugin.dll";QLibrary* L = new QLibrary(library_path);if( nullptr == L) return -1;if(! L->load()){qDebug() << "[error:]" << L->errorString();delete L;L = NULL;}func_name funcname = (func_name)L->resolve("func_name");const char* name = funcname();qDebug()<<name;func_no   funcno = (func_no)L->resolve("func_no");int no = funcno();qDebug()<<no;L->unload();return a.exec();}

只是个示例,不要忘了释放,释放要在动态库里面释放,

主要的申请和释放改一下

void* create(const char* url, func_callback callback)
{PluginContext* con = (PluginContext*) malloc(sizeof(PluginContext));con->url = url;return con;
}
void Release(void* context)
{free(context);
}

ok, 成功执行,没有问题
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/48746.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【前端学习笔记】CSS基础一

一、什么是CSS 1.CSS 介绍 CSS&#xff08;Cascading Style Sheets&#xff0c;层叠样式表&#xff09;是一种用来控制网页布局和设计外观的样式语言。它使得开发者可以分离网页的内容&#xff08;HTML&#xff09;和表现形式&#xff08;样式&#xff09;&#xff0c;提高了…

Spring Security 介绍

1.概要 Spring Security是一个用于在Java应用程序中实现身份验证和访问控制的强大框架。它可以轻松地集成到任何基于Spring的应用程序中&#xff0c;提供了一套丰富的功能来保护应用程序的安全性。 https://spring.io/projects/spring-security/ demo:https://docs.spring.i…

unity2D游戏开发02添加组件移动玩家

添加组件 给PlayGame和EnemyObject添加组件BoxCollider 2D碰撞器&#xff0c;不用修改参数 给PlayGame添加组件Rigibody 2D 设置数据 添加EnemyObject&#xff0c;属性如下 Edit->project setting->Physics 2D 将 y的值改为0 给playerObject添加标签 新建层 将PlayerObj…

美团后端二面

美团后端二面 ……………………………… 两道场景 一道 数字转中文读法&#xff08;1000-》一千&#xff09; 0八股0自我介绍 反问 “您觉得我能过吗&#xff1f;” “这个需要横行对比之后才能有结果” ……………………………… 什么时候到岗 场景题 1 假设我有一个…

ETL工程师角度下的SQL优化

作为ETL&#xff08;Extract, Transform, Load&#xff09;工程师&#xff0c;SQL优化是提高数据处理和分析效率的关键一环。优化SQL查询可以显著降低数据处理时间&#xff0c;提高ETL过程的性能。本文将从 合理设计数据模型&#xff1a;在ETL过程中&#xff0c;正确的数据模型…

主从DNS服务器

实验 3 &#xff1a;主从 DNS 服务器 将一个区域文件复制到多个服务器上的过程叫做区域传送。将主服务器上的信息复制到辅助服务器上来 实现。 &#xff08; 1 &#xff09;完全区域传送&#xff1a;复制整个区域文件 查看日志 # 主 DNS 服务器的配置【主 dns 服务器的 ip 地…

【STM32 HAL库】ADC

ADC&#xff0c;顾名思义就是模拟信号->数字信号ADC工作原理 分类&#xff1a; 并联比较型-----转换速度快-----成本高、功耗高、分辨率低 分压部分比较部分编码部分&#xff08;其中Vx为模拟电压输入 &#xff09; 逐次逼近型-----结构简单&#xff0c;功耗低-----转换速…

Preact:轻量级替代React的选择

Preact是一个轻量级的JavaScript库&#xff0c;它提供了与React相似的API&#xff0c;但体积更小&#xff0c;性能更优。Preact的核心理念是尽可能地保持与React的兼容性&#xff0c;同时去除不必要的部分&#xff0c;使其成为一个理想的替代品&#xff0c;尤其是在对性能和包大…

C++STL详解(三)——vector类的接口详解

目录 一.vector的介绍 二.vector的构造以及赋值 2.1构造函数 2.2operator重载 三.vector的空间操作 3.1capacity和size函数 3.2reserve和resize函数 3.3empty函数 四.vector迭代器相关函数 4.1begin和end函数 4.2rbegin和rend函数 五.vector的增删查改 5.1push_back和…

web前端 React 框架面试200题(一)

面试题 1. 简述什么是React &#xff08; 概念 &#xff09;&#xff1f; 参考回答&#xff1a; 1、React是Facebook开发的一款JS库。 2、React一般被用来作为MVC中的V层&#xff0c;它不依赖其他任何的库&#xff0c;因此开发中&#xff0c;可以与任何其他的库集成使用&…

QT串口和数据库通信

创建串口 串口连接客户端并向服务器发送消息 client.pro #------------------------------------------------- # # Project created by QtCreator 2024-07-02T14:11:20 # #-------------------------------------------------QT core gui network QT core gui…

【React】箭头函数:现代 JavaScript 的高效编程方式

文章目录 一、箭头函数的基本语法二、箭头函数的特性三、在 React 中的常见用法四、最佳实践 在现代 JavaScript 中&#xff0c;箭头函数&#xff08;Arrow Functions&#xff09;是一种简洁的函数表达方式&#xff0c;并且在 React 开发中非常常见。箭头函数不仅简化了函数的语…

RockyLinux 9 PXE Server bios+uefi 自动化部署 RockLinux 8 9

pxe server 前言 PXE&#xff08;Preboot eXecution Environment&#xff0c;预启动执行环境&#xff09;是一种网络启动协议&#xff0c;允许计算机通过网络启动而不是使用本地硬盘。PXE服务器是实现这一功能的服务器&#xff0c;它提供了启动镜像和引导加载程序&#xff0c;…

前端开发知识(三)-javascript

javascript是一门跨平台、面向对象的脚本语言。 一、引入方式 1.内部脚本&#xff1a;使用<script> &#xff0c;可以放在任意位置&#xff0c;也可以有多个&#xff0c;一般是放在<body></body>的下方。 2.外部脚本&#xff1a;单独编写.js文件&#xff…

【HarmonyOS】应用设置屏幕常亮

【HarmonyOS】应用设置屏幕常亮 一、问题背景&#xff1a; 金融类或钱包场景的应用APP&#xff0c;对于付款码&#xff0c;扫一扫等场景都会对屏幕设置常亮。防止屏幕长时间不操作&#xff0c;自动息屏。 目前这种场景的需求也是非常有必要的&#xff0c;也是行业内默认的处理…

Spark 解析嵌套的 JSON 文件

1、什么是嵌套的JSON文件&#xff1f; 嵌套的JSON文件是指文件中包含了嵌套的JSON对象或数组。例如&#xff0c;以下是一个嵌套的JSON文件的示例&#xff1a; {"name": "John","age": 30,"address": {"street": "123…

解码目标检测:可解释性的关键角色

解码目标检测&#xff1a;可解释性的关键角色 在人工智能的浪潮中&#xff0c;目标检测作为计算机视觉领域的一个核心任务&#xff0c;已经取得了显著的进展。然而&#xff0c;随着深度学习模型在这一领域的广泛应用&#xff0c;模型的可解释性逐渐成为研究者关注的焦点。本文…

HarmonyOS实现跨语言交互(Node-API)

Node-API简介 通过Native接口&#xff0c;实现两种代码的交互。 是在Node.js提供的Node-API基础上扩展而来&#xff0c;但与Node.js中的Node-API不完全兼容。本质就是提供了对C/C代码的使用接口&#xff0c;使得两种代码共同工作。规范I/O、CPU密集型、OS底层等能力。 应用场景…

工作中es客户端常见使用错误

背景&#xff1a; 7月9日因阿里云底层网络故障导致使用阿里云产品&#xff08;redis&#xff0c;rocketmq等&#xff09;均受影响&#xff0c;因为业务依赖mq异步将数据写入elasticsearch中&#xff0c;mq发送失败导致es部分数据丢失。丢失的数据需要从mysql中恢复到es中&…

景区AR导航营销系统:技术解决方案与实施效益分析

随着旅游市场的竞争日益激烈&#xff0c;景区需要不断创新以吸引游客。景区 AR 导航将虚拟画面与现实场景相结合&#xff0c;为游客提供了更加直观、生动的导航服务。对于景区而言&#xff0c;这一创新技术无疑是吸引游客目光、提升景区知名度的有力武器。通过独特的 AR 导航体…