WPS C++ 二次开发 Demo运行

1.官网二次开发地址:https://open.wps.cn/docs/client/wpsLoad

 2.Demo源码下载:

        经过测试上述链接找不到demo源码,可通过git命令下载:

git clone https://code.aliyun.com/zouyingfeng/wps.git -b dev

        图中cpp文件夹即为c++demo源码;

3.环境搭建:

        3.1.Linux操作系统,可安装对应虚拟机,本人安装centos7虚拟机进行实验;

        3.2.qt4或qt5安装,本人使用qt5.9.4;

        3.3.WPS Office 2019 For Linux下载和安装:

        

        这里注意,Ubuntu系统选择Deb下载,Centos选择Rpm格式;

        到rpm文件目录下打开终端运行:

rpm -ivh wps-office-11.1.0.11691-1.x86_64.rpm

        安装过程可能会报错提示缺少一个库,提示缺少libXss.so.1文件,执行如下命令查看提供方

repoquery --nvr --whatprovides libXss.so.1
sudo yum install libXScrnSaver-1.2.2-6.1.el7

        然后重新执行rpm安装命令,安装成功,安装成功后默认安装到/opt目录下,桌面生成了wps图标,但是点击没反应,到安装目录下用命令行执行,启动不起来,提示GLIBC版本不对,因为wps编译时使用的glibc_2.18,而本地最高只到2.17.

        可通过如下命令查看版本:

strings /lib64/libc.so.6 | grep GLIBC

         如果版本不够2.18需要下载源码编译:(centos7用户这里千万不要编译到系统盘下,否则会导致虚拟机重启后无法进入桌面系统!!!最好的方法是编译到/home下某个目录,然后把编译好的库放到/opt下的wps目录下,切记切记!!!!)

wget http://mirrors.ustc.edu.cn/gnu/libc/glibc-2.18.tar.gz

tar zxvf glibc-2.18.tar.gz 

cd glibc-2.18/

mkdir build

cd build/

export LD_LIBRARY_PATH=../

sudo ../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin

sudo make -j4

sudo make install

         此时运行wps可启动软件,但是打开文档时提示缺少部分字体:

        先下载,后解压,然后拷贝到/usr/share/fonts下:

        链接: https://pan.baidu.com/s/1mNXRWg0fomuigEEvoEOWKw 提取码: 77d6 

        重新打开软件可正常使用。

4.demo运行:

        使用qtcreator打开cpp目录下的pro工程文件:

        构建工程后启动程序:

 

         至此,demo运行起来了,后续可基于此进行自定义开发!

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux下使用C++调用SQLIST的库,需要进行以下步骤: 1. 安装SQLIST库 可以通过包管理器或者官网下载SQLIST库,并进行安装。如使用Ubuntu系统,可以通过以下命令进行安装: ``` sudo apt-get install libsqlite3-dev ``` 2. 包含头文件 在C++代码中需要包含SQLIST库的头文件,如下: ```c++ #include <sqlite3.h> ``` 3. 打开数据库 使用`sqlite3_open`函数打开数据库,该函数的第一个参数为数据库文件的路径,第二个参数为指向sqlite3的指针。如下: ```c++ sqlite3 *db; int rc = sqlite3_open("test.db", &db); if (rc) { cerr << "Can't open database: " << sqlite3_errmsg(db) << endl; sqlite3_close(db); exit(1); } ``` 4. 执行SQL语句 使用`sqlite3_exec`函数执行SQL语句,该函数的第一个参数为指向sqlite3的指针,第二个参数为要执行的SQL语句,第三个参数为回调函数,第四个参数为回调函数的参数。如下: ```c++ int callback(void *data, int argc, char **argv, char **azColName){ int i; fprintf(stderr, "%s: ", (const char*)data); for(i=0; i<argc; i++){ printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); return 0; } char *sql = "SELECT * FROM test_table"; char *zErrMsg = 0; rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if( rc != SQLITE_OK ){ fprintf(stderr, "SQL error: %s\n", zErrMsg); sqlite3_free(zErrMsg); } ``` 5. 关闭数据库 使用`sqlite3_close`函数关闭数据库,该函数的参数为指向sqlite3的指针。如下: ```c++ sqlite3_close(db); ``` 以上就是在Linux下使用C++调用SQLIST库的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值