在Linux下使用wxWidgets进行跨平台GUI开发(二)

wxWidgets常见辅助类的应用示例

wxWidgets提供了一系列功能强大的辅助类(Helper Classes),涵盖了字符串处理、文件操作、XML解析、数据流、数据库和网络通信等功能,这些类为跨平台GUI开发提供了基础工具支持,帮助开发者完成各种任务。

wxWidgets库可用于创建控制台和图形界面(GUI)应用程序。本文将通过一些控制台应用程序的示例,阐述部分核心辅助类的使用方法。

Console示例

好,那现在让我们跟着ZetCode教程上的示例。第一个非常简单的控制台程序
一个非常简单的控制台程序:

// console.cpp #include <wx/wx.h> // 必须得加上这个头文件 #include <wx/string.h>  int main(int argc, char **argv) {     wxPuts(wxT("A wxWidgets console application")); } 

对应的CMakeLists.txt文件:

cmake_minimum_required(VERSION 3.10) project(console)  find_package(wxWidgets REQUIRED COMPONENTS core) include(${wxWidgets_USE_FILE})  add_executable(${PROJECT_NAME} console.cpp) target_link_libraries(${PROJECT_NAME} ${wxWidgets_LIBRARIES}) set(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}) 

然后因为现在是VS Code开发,所以需要改一个调试配置文件launch.json,找到

"program": "${workspaceFolder}/hello", 更改为 "program": "${workspaceFolder}/console", 现在你应该能顺利构建编译运行,这将在控制台终端输出 A wxWidgets console application 好的,现在我们将console.cpp和CMakeLists.txt文件复制到Windows平台,是的,我们的目的是要跨平台的,现在我们来做这件事。 在Windows上找到一个工作空间(注意路径字符规范),还是创建test文件夹,把要复制的两个文件拷贝到里面。 进入cmd命令行,还是将构建文件放到build下。 cmake -B build 

然后生成可执行文件大概会出错,需修改CMakeLists.txt文件(确保跨平台):

cmake_minimum_required(VERSION 3.10) project(console)  if(WIN32)     find_package(wxWidgets 3.2.4 REQUIRED COMPONENTS core base adv html xml net aui stc xrc gl media qa richtext propgrid ribbon webview) else()     find_package(wxWidgets 3.2.4 REQUIRED COMPONENTS core base) endif()  include(${wxWidgets_USE_FILE}) add_executable(${PROJECT_NAME} console.cpp) target_link_libraries(${PROJECT_NAME} ${wxWidgets_LIBRARIES})  if(MSVC)     target_include_directories(${PROJECT_NAME} PUBLIC "${wxWidgets_INCLUDE_DIRS}/msvc") endif()  set(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}) 

现在可以构建并生成可执行文件了,在cmd中键入
cmake --build ./build
这会根据默认构建系统在build文件夹里生成程序。如果你安装了Visual Studio则默认使用msvc工具链,你将会在build下看到一个sln解决方案,你也可以打开解决方案在IDE下生成可执行程序。

wxString类示例

wxString是一个表示字符串的类。在下面的示例中,我们定义了三个wxString对象。我们通过加法运算将这些字符串组合成一个新的字符串。

字符串连接

// addition.cpp #include <wx/wx.h> #include <wx/string.h>  int main(int argc, char **argv) {     wxString str1 = wxT("Linux");     wxString str2 = wxT("Operating");     wxString str3 = wxT("System");     wxString str = str1 + wxT(" ") + str2 + wxT(" ") + str3;     wxPuts(str); } 

输出:

Linux Operating System 

你可以练习使用CMake生成这个可执行程序,当然你可以在Linux终端使用

g++ addition.cpp `wx-config --cxxflags --libs` -o addition 

更简洁地生成可执行文件。

字符串格式化

// formatted.cpp #include <wx/wx.h> #include <wx/string.h>  int main(int argc, char **argv) {     int flowers = 21;     wxString str;     str.Printf(wxT("There are %d red roses."), flowers);     wxPuts(str); } 

输出:

There are 21 red roses. 

以下示例演示了如何检查一个字符串是否包含另一个字符串,为此我们使用了Contains方法。(注:根据编程语言或框架的不同,类似功能可能有不同命名,如includes()、find()、contains()等,但作用相同。)

字符串包含检查

// contains.cpp #include <wx/wx.h> #include <wx/string.h>  int main(int argc, char **argv) {     wxString str = wxT("The history of my life");     if (str.Contains(wxT("history"))) {         wxPuts(wxT("Contains!"));     }     if (!str.Contains(wxT("plain"))) {         wxPuts(wxT("Does not contain!"));     } } 

输出:

Contains! Does not contain! 

Len方法返回字符串中的字符数。(补充说明:对于多字节字符(如中文),不同语言处理方式可能不同,有些按字符数统计,有些按字节数统计)

字符串长度

// length.cpp #include <wx/wx.h> #include <wx/string.h>  int main(int argc, char **argv) {     wxString str = wxT("The history of my life");     wxPrintf(wxT("The string has %d charactersn"), str.Len()); } 

输出:

The string has 22 characters 

大小写转换

// cases.cpp #include <wx/wx.h> #include <wx/string.h>  int main(int argc, char **argv) {     wxString str = wxT("The history of my life");     wxPuts(str.MakeLower());     wxPuts(str.MakeUpper()); } 

输出:

the history of my life THE HISTORY OF MY LIFE 

实用工具函数

(编程概念说明:这类函数通常指不依赖对象状态、独立完成特定任务的辅助函数)
wxWidgets 提供了多个实用的工具函数,用于执行进程、获取用户主目录或获取操作系统名称。
在以下示例中,我们执行了 ls 命令(仅限 Unix 系统),为此我们使用了 wxShell 函数。

执行shell命令

// shell.cpp #include <wx/wx.h> #include <wx/string.h> #include <wx/utils.h>  int main(int argc, char **argv) {     wxShell(wxT("ls -l")); } 

这将输出当前路径下的文件统计信息。
接下来我们将获取用户主目录、操作系统名称、用户名、主机名以及内存空闲总量。

获取系统信息

// system.cpp #include <wx/wx.h> #include <wx/string.h> #include <wx/utils.h>  int main(int argc, char **argv) {     wxPuts(wxGetHomeDir());     wxPuts(wxGetOsDescription());     wxPuts(wxGetUserName());     wxPuts(wxGetFullHostName());     long mem = wxGetFreeMemory().ToLong();     wxPrintf(wxT("Memory: %ldn"), mem); } 

这将输出系统及用户等统计信息。

时间和日期处理

在wxWidgets中,我们提供了多个用于处理日期和时间的类。
该示例展示了以不同格式显示的当前日期或时间。

当前日期时间格式化

// datetime.cpp #include <wx/wx.h> #include <wx/datetime.h>  int main(int argc, char **argv) {     wxDateTime now = wxDateTime::Now();     wxString date1 = now.Format();     wxString date2 = now.Format(wxT("%X"));     wxString date3 = now.Format(wxT("%x"));     wxPuts(date1);     wxPuts(date2);     wxPuts(date3); } 

输出示例:

Wed Jun 11 16:18:09 2025 16:18:09 06/11/25 

不同城市时间

// datetime2.cpp #include <wx/wx.h> #include <wx/datetime.h>  int main(int argc, char **argv) {     wxDateTime now = wxDateTime::Now();     wxPrintf(wxT(" Tokyo: %sn"), now.Format(wxT("%a %T"), wxDateTime::GMT9).c_str());     wxPrintf(wxT(" Moscow: %sn"), now.Format(wxT("%a %T"), wxDateTime::MSD).c_str());     wxPrintf(wxT("Budapest: %sn"), now.Format(wxT("%a %T"), wxDateTime::CEST).c_str());     wxPrintf(wxT(" London: %sn"), now.Format(wxT("%a %T"), wxDateTime::WEST).c_str());     wxPrintf(wxT("New York: %sn"), now.Format(wxT("%a %T"), wxDateTime::EDT).c_str()); } 

输出示例:

 Tokyo: Wed 17:23:43  Moscow: Wed 12:23:43 Budapest: Wed 10:23:43  London: Wed 09:23:43 New York: Wed 04:23:43 

日期跨度

以下示例展示了如何向日期/时间添加日期跨度。我们将当前时间增加一个月。

// datespan.cpp #include <wx/wx.h> #include <wx/datetime.h>  int main(int argc, char **argv) {     wxDateTime now = wxDateTime::Now();     wxString date1 = now.Format(wxT("%B %d %Y"));     wxPuts(date1);     wxDateSpan span(0, 1);     wxDateTime then = now.Add(span);     wxString date2 = then.Format(wxT("%B %d %Y"));     wxPuts(date2); } 

输出示例:

June 11 2025 July 11 2025 

文件操作

wxWidgets 提供了多个类来简化文件操作。这是对文件的底层访问,与流式操作不同。
在以下示例中,我们使用 wxFile 类创建新文件并写入数据,同时会检测文件是否已打开。需注意:创建文件时会自动保持打开状态。

创建和写入文件

// createfile.cpp #include <wx/wx.h> #include <wx/file.h>  int main(int argc, char **argv) {     wxString str = wxT("You make me want to be a better man.n");     wxFile file;     file.Create(wxT("quote"), true);     if (file.IsOpened())         wxPuts(wxT("the file is opened"));     file.Write(str);     file.Close();     if (!file.IsOpened())         wxPuts(wxT("the file is not opened")); } 

终端交互示例:

$ ls quote ls: quote: No such file or directory $ ./createfile the file is opened the file is not opened $ cat quote You make me want to be a better man. 

wxTextFile 是一个简易的文本文件操作类,支持以行为单位处理文本文件。相比 wxFile 类,使用这个类会更加便捷。
在接下来的示例中,我们将输出文件的行数、首行和末行内容,最终读取并显示文件的全部内容。

文本文件操作

// readfile.cpp #include <wx/wx.h> #include <wx/textfile.h>  int main(int argc, char **argv) {     wxTextFile file(wxT("test.c"));     file.Open();     wxPrintf(wxT("Number of lines: %dn"), file.GetLineCount());     wxPrintf(wxT("First line: %sn"), file.GetFirstLine().c_str());     wxPrintf(wxT("Last line: %sn"), file.GetLastLine().c_str());     wxPuts(wxT("----------------------------------------"));     wxString s;     for ( s = file.GetFirstLine(); !file.Eof();         s = file.GetNextLine() )     {         wxPuts(s);     }     file.Close(); } 

test.c内容:

#include <glib.h> #include <glib/gstdio.h>  int main() {     g_mkdir("/home/vronskij/test", S_IRWXU); } 

输出:

Number of lines: 8 First line: #include <glib.h> Last line: } ---------------------------------------- #include <glib.h> #include <glib/gstdio.h>  int main() {     g_mkdir("/home/vronskij/test", S_IRWXU); } 

目录枚举

在以下示例中,我们将打印当前工作目录下的所有文件和目录。

// dir.cpp #include <wx/wx.h> #include <wx/dir.h> #include <wx/filefn.h>  int main(int argc, char **argv) {     wxDir dir(wxGetCwd());     wxString file;     bool cont = dir.GetFirst(&file, wxEmptyString, wxDIR_FILES | wxDIR_DIRS);     while (cont) {         wxPuts(file);         cont = dir.GetNext(&file);     } } 

输出示例:

dir dir.cpp temp console basic.cpp basic quote createfile console.cpp basic.cpp~ test.c console.cpp~ ...... 

辅助类的应用示例暂且介绍到这里了,后续进行正式的wxWidgets开发说明。

发表评论

评论已关闭。

相关文章