java的GUI之SWT框架 JavaFX框架 配置开发环境(包含但不限于WindowBuilder完整教程,解决Unknown GUI toolkit报错,解决导入SWT包错误)
官网(资料挺多的,API文档截图以及示例都有):https://www.eclipse.org/swt/
克隆官方仓库
git clone --depth=1 git://git.eclipse.org/gitroot/platform/eclipse.platform.swt.git
里面只有 org.eclipse.swt.snippets 目录里面有 300多个代码片段,初学直接看这部分源码即可。
其他 example 目录是成品小 demo,学完snippet再看,然后就能做东西了
本次环境:
Eclipse IDE for Java Developers
Version: 2018-12 (4.10.0)
Build id: 20181214-0600
JAVA:JDK11
Windows10 Pro 预览版 18334——19H1
去网上找了配置SWT开发环境的,发现很多教程都过时了。SWT是一个利用Java的JNI对接原生系统的框架
(做到了系统原生里有的GUi Api 就尽量用系统的,没有的就绘制,大大提高了运行效率,是真正可以考虑的贴合系统的GUI,不过理论上移植性比Swing Awt差点)
被GFW和Dns污染光环之下的请换源(享受秒开的喜悦):https://lug.ustc.edu.cn/wiki/mirrors/help/eclipse#使用科大镜像更新插件
一,Eclipse里安装WindowBuilder来可视化设计SWT程序的完整教程
(完美解决Unknown GUI toolkit或无法导入swt包的错误报错):
如果仅仅是想在Eclipse里使用WindowBuilder来可视化设计SWT程序,可以参考按这里做:eclipse安装WindowBuilder插件以及简单使用(近更) - Akatsuki - CSDN博客 (如果last good build不行可以选第一个Lastest)
注意:上面这教程中的
“然后进入到工程,右键src->new->other->WindowBuilder->Swing Designer->Application Window->next->起名->Finish”
应改为:
“然后进入到工程,右键src->new->Packages,(必须勾上Create package-info.java),再右击src->other->WindowBuilder->Swing Designer->SWT->Application Window->next->起名->Finish”
然后如果design界面还是用不了,提示Unknown GUI toolkit The parser parsed the compilation unit, but can't identifyany GUI toolkit, If you wish to use SWT,please add the appropriate SWT jars to your classpath, or create a new SWT/JF
点击Switch to code切换到代码区
然后就如下图操作(点击代码区import所在行号栏里的×号):
点击+号展开import,再双击 Add 'requires org.*' to module-info.java
然后打开同工程里的module-info.java,鼠标悬浮在requires后面的org.eclipse.swt.win32.win32.x86_64上,然后双击Move classpath entry 'org.eclipse.swt.win32*',
如果有 requires swt; 那一行就删掉(因为我截图里写错了又懒得改)
为什么需要在module-info.java里添加requires?这是Java9引入的新特性,至于作用和用法,我还在思考....
然后SWT报错少了一些,嗯,快成功了。
先下载swt.jar并解压到任意一个目录,下载请看这里:下载SWT
导入SWT的ClassPath
在Eclipse里添加额外的Class Folder,选择解压好的目录(即swt.jar所在目录)
然后再添加DLL支持,具体操作实例:
在Eclipse安装目录下的plugins目录下,找到文件org.eclipse.swt.win32.win32.x86_64_3.109.0.v20181204-1801.jar(x86_64后面的是版本号,你我的可能版本略微不同),复制出来并解压到某一目录(该jar文件里面有4个dll文件)
然后在Eclipse包资源管理器中,右击项目名 → 导入 → 常规 → 文件系统 → 下一步 → 浏览 并选择dll文件所在目录,勾选4个dll文件确认即可。
发现包资源管理器都没红×了吧!那就是成功了
最后点Main.java(Eclipse生成的swt程序示例),然后切换design界面,点Reparse重新加载可视化界面即可
最后效果:
测试添加组件(一切正常)
附上包资源一栏截图:
二,在非Eclipse里配置SWT开发环境,例如VSCode
1,下载SWT:
进入https://www.eclipse.org/swt/
在Lastest Release里点击你Eclipse对应的版本号。
进入后你会发现这里有你选择的Eclipse版本所对应的全部SDK及其运行环境(如下图),
往下翻找到SWT Binary and Source,点击swt-<Eclipse版本号>-win32-win32-x86_64.zip下载即可
下载完成。
写好HelloWorld 并按照以下目录结构放置
+ lib
- swt.jar
+ src
- HelloWorld.java
1 package org.yu; 2 3 /** 4 * Hello world! 5 * 6 */ 7 8 import org.eclipse.swt.widgets.Display; 9 import org.eclipse.swt.widgets.Shell; 10 import org.eclipse.swt.SWT; 11 12 public class App { 13 public static void main(String[] args){ 14 Display aDisplay = new Display(); 15 Shell shell = new Shell(aDisplay,SWT.); 16 shell.setLocation(200, 200); 17 shell.setSize(400, 300); 18 shell.setText("Title is Mine"); 19 shell.open(); 20 21 while (!shell.isDisposed()) // 窗体是否关闭 22 { 23 if (!aDisplay.readAndDispatch()) // 检验 Display 线程状态是否忙 24 aDisplay.sleep(); // Display 类线程休眠 25 } 26 27 aDisplay.dispose(); // 注销 Display 对象资源 28 } 29 }
测试一下
javac -classpath "../lib/swt.jar" HelloWorld.java
2,配置SWT环境(以VSCode为例)
配好JDK环境变量,然后按照VSCode官方说明安装好Java插件,然后有几种方法:
一:把 swt.jar 加入CLASSPATH变量如 E:\japi\swt.jar,然后在VSCode里设置,特别麻烦....(但是可以用到最新版4.924)
1 <?xml version="1.0" encoding="UTF-8"?> 2 3 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 4 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 5 <modelVersion>4.0.0</modelVersion> 6 7 <groupId>org.yu</groupId> 8 <artifactId>demoSwt</artifactId> 9 <version>1.0-SNAPSHOT</version> 10 11 12 13 <name>demoSwt</name> 14 <!-- FIXME change it to the project's website --> 15 <url>http://www.example.com</url> 16 17 <repositories> 18 <repository> 19 <id>maven-eclipse-repo</id> 20 <url>http://maven-eclipse.github.io/maven</url> 21 </repository> 22 </repositories> 23 24 <properties> 25 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 26 <maven.compiler.source>1.8</maven.compiler.source> 27 <maven.compiler.target>1.8</maven.compiler.target> 28 <swt.version>4.6.1</swt.version> 29 </properties> 30 31 <dependencies> 32 <dependency> 33 <groupId>junit</groupId> 34 <artifactId>junit</artifactId> 35 <version>4.11</version> 36 <scope>test</scope> 37 </dependency> 38 <!-- <dependency> 39 <groupId>org.eclipse.swt</groupId> 40 <artifactId>org.eclipse.swt.win32.win32.x86</artifactId> 41 <version>${swt.version}</version> 42 - To use the debug jar, add this - 43 <classifier>debug</classifier> 44 </dependency> --> 45 <!-- <dependency> 46 <groupId>org.eclipse.swt</groupId> 47 <artifactId>org.eclipse.swt.win32.win32.x86_64</artifactId> 48 <version>${swt.version}</version> 49 </dependency> --> 50 <!-- <dependency> 51 <groupId>org.eclipse.swt</groupId> 52 <artifactId>org.eclipse.swt.gtk.linux.x86</artifactId> 53 <version>${swt.version}</version> 54 <classifier>debug</classifier> 55 </dependency> --> 56 <dependency> 57 <groupId>org.eclipse.swt</groupId> 58 <artifactId>org.eclipse.swt.gtk.linux.x86_64</artifactId> 59 <version>${swt.version}</version> 60 <classifier>debug</classifier> 61 </dependency> 62 <!-- <dependency> 63 <groupId>org.eclipse.swt</groupId> 64 <artifactId>org.eclipse.swt.cocoa.macosx.x86_64</artifactId> 65 <version>${swt.version}</version> 66 </dependency> --> 67 </dependencies> 68 69 <build> 70 <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --> 71 <plugins> 72 <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle --> 73 <plugin> 74 <artifactId>maven-clean-plugin</artifactId> 75 <version>3.1.0</version> 76 </plugin> 77 <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging --> 78 <plugin> 79 <artifactId>maven-resources-plugin</artifactId> 80 <version>3.0.2</version> 81 </plugin> 82 <plugin> 83 <artifactId>maven-compiler-plugin</artifactId> 84 <version>3.8.0</version> 85 </plugin> 86 <plugin> 87 <artifactId>maven-surefire-plugin</artifactId> 88 <version>2.22.1</version> 89 </plugin> 90 <plugin> 91 <artifactId>maven-jar-plugin</artifactId> 92 <version>3.0.2</version> 93 </plugin> 94 <plugin> 95 <artifactId>maven-install-plugin</artifactId> 96 <version>2.5.2</version> 97 </plugin> 98 <plugin> 99 <artifactId>maven-deploy-plugin</artifactId> 100 <version>2.8.2</version> 101 </plugin> 102 <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle --> 103 <plugin> 104 <artifactId>maven-site-plugin</artifactId> 105 <version>3.7.1</version> 106 </plugin> 107 <plugin> 108 <artifactId>maven-project-info-reports-plugin</artifactId> 109 <version>3.0.0</version> 110 </plugin> 111 </plugins> 112 </pluginManagement> 113 </build> 114 </project>
附上Maven换源方法:
1 ~/.m2$ cat settings.xml 2 <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" 3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 4 xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 5 https://maven.apache.org/xsd/settings-1.0.0.xsd"> 6 7 <mirrors> 8 <mirror> 9 <id>alimaven</id> 10 <name>aliyun maven</name> 11 <url>http://maven.aliyun.com/nexus/content/groups/public/</url> 12 <mirrorOf>central</mirrorOf> 13 </mirror> 14 </mirrors> 15 </settings>
Maven 方式只在 Linux 下测试通过,Windows 可能还需用把dll文件放到class生成目录里(可能),MacOSX(买不起....)
但是Maven私人仓库的已经停更了,懂的可以自己做个私人仓库更新到最新版,然后按照原作者那样放 github 就行(不用服务器)
效果图(由于SWT的原理,所以皮肤会和系统一致)
没有关闭按钮:只是因为用了SWT.NO这个常量
Ps.如果提示:
Exception in thread "main" java.lang.UnsatisfiedLinkError: Cannot load 32-bit SWT libraries on 64-bit JVM
那么就把32位库拿开,只用64位库,用Maven的只需改一下pom.xml
最后放个快速入门资料(在两个qq群找到的,非常感谢他们,侵权请联系):
链接: https://pan.baidu.com/s/1zid8jDgl4wQFSle2OD3lcg
提取码: dbw5
当然在 百度文档搜 SWT 也是能找到不少资料的(想不到吧hh)
引用一句话:JFace与SWT的关系好比Microsoft的MFC与SDK的关系
最后,现在建议使用 JavaFX,官方支持的,参照了 SWT 调用系统底层的方式,这样保证稳定性和样式与系统的一致性
学过JAVA ,想学GUI。网友说swing awt被淘汰了。请教现在主流的JAVA gui开发学啥?- 知乎
JavaFX,更先进的图形库
中文准官网 https://openjfx.cn 其主页的文档收集的比官网 openjfx.io 好很多
以及 Maven 库
JavaFx的lib如下,可见包含了SWT Swing Fxml等优点,JDK8自带,而从JDK9开始JavaFX独立了出来(可能是考虑到全球桌面软件市场萎缩的原因)
JavaFX资料
https://www.jetbrains.com/help/idea/javafx.html#
https://openjfx.io/openjfx-docs/#IDE-Intellij
javafx自动缩放例子 按照淘宝自适应框架方法便编写-Main.java 公式(DPR = 物理像素 宽/高 , fontsize/= DPR)
可以用Maven或Gradle来管理依赖,这是我 javaFx 项目里的 pom.xml (最重要的是两个 JavaFX 的依赖,以及一个JavaFX的maven plugin)
1 <?xml version="1.0" encoding="UTF-8"?> 2 3 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 4 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 5 <modelVersion>4.0.0</modelVersion> 6 7 <groupId>com.demo</groupId> 8 <artifactId>BookManage</artifactId> 9 <version>1.0-SNAPSHOT</version> 10 11 <name>BookManage</name> 12 <!-- FIXME change it to the project's website --> 13 <url>http://www.example.com</url> 14 15 16 <properties> 17 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 18 <maven.compiler.source>11</maven.compiler.source> 19 <maven.compiler.target>11</maven.compiler.target> 20 <fx.version>11</fx.version> 21 </properties> 22 <dependencies> 23 <!-- JavaFX--> 24 <dependency> 25 <groupId>org.openjfx</groupId> 26 <artifactId>javafx-controls</artifactId> 27 <version>${fx.version}</version> 28 </dependency> 29 <dependency> 30 <groupId>org.openjfx</groupId> 31 <artifactId>javafx-fxml</artifactId> 32 <version>${fx.version}</version> 33 </dependency> 34 35 36 <dependency> 37 <groupId>junit</groupId> 38 <artifactId>junit</artifactId> 39 <version>4.12</version> 40 <scope>test</scope> 41 </dependency> 42 43 <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok --> 44 <dependency> 45 <groupId>org.projectlombok</groupId> 46 <artifactId>lombok</artifactId> 47 <version>1.18.12</version> 48 <scope>provided</scope> 49 </dependency> 50 51 52 </dependencies> 53 54 <build> 55 <resources> 56 <resource> 57 <directory>src/main/java</directory> 58 <includes> 59 <include>**/*.*</include> 60 <include>**/*.yml</include> 61 <include>**/*.properties</include> 62 <include>**/*.css</include> 63 <include>**/*.fxml</include> 64 </includes> 65 <filtering>false</filtering> 66 </resource> 67 <resource> 68 <directory>src/main/resources</directory> 69 <includes> 70 <include>**/*.*</include> 71 <include>**/*.yml</include> 72 <include>**/*.properties</include> 73 <include>**/*.css</include> 74 <include>**/*.fxml</include> 75 </includes> 76 <filtering>false</filtering> 77 </resource> 78 </resources> 79 80 <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --> 81 <plugins> 82 <!-- javaFX JDK11+ needed--> 83 <plugin> 84 <groupId>org.openjfx</groupId> 85 <artifactId>javafx-maven-plugin</artifactId> 86 <version>0.0.4</version> 87 <configuration> 88 <mainClass>com.demo.App</mainClass> 89 </configuration> 90 </plugin> 91 92 93 <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle --> 94 <plugin> 95 <artifactId>maven-clean-plugin</artifactId> 96 <version>3.1.0</version> 97 </plugin> 98 <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging --> 99 <plugin> 100 <artifactId>maven-resources-plugin</artifactId> 101 <version>3.0.2</version> 102 </plugin> 103 <plugin> 104 <artifactId>maven-compiler-plugin</artifactId> 105 <version>3.8.0</version> 106 <configuration> 107 <source>11</source> 108 <target>11</target> 109 </configuration> 110 </plugin> 111 <plugin> 112 <artifactId>maven-surefire-plugin</artifactId> 113 <version>2.22.1</version> 114 </plugin> 115 <plugin> 116 <artifactId>maven-jar-plugin</artifactId> 117 <version>3.0.2</version> 118 </plugin> 119 <plugin> 120 <artifactId>maven-install-plugin</artifactId> 121 <version>2.5.2</version> 122 </plugin> 123 <plugin> 124 <artifactId>maven-deploy-plugin</artifactId> 125 <version>2.8.2</version> 126 </plugin> 127 <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle --> 128 <plugin> 129 <artifactId>maven-site-plugin</artifactId> 130 <version>3.7.1</version> 131 </plugin> 132 <plugin> 133 <artifactId>maven-project-info-reports-plugin</artifactId> 134 <version>3.0.0</version> 135 </plugin> 136 </plugins> 137 </pluginManagement> 138 </build> 139 </project>
然后在配置IDEA的运行程序的configuration,添加Maven选项,然后填入参数 javafx:run 即可(这个javafx:run 就是上面pom里的plugin)
JDK14+JAVAFX14+Maven定制jre打包瘦身,必成版
注意:一键列出当前目录jar包的依赖可以用命令
jdeps --list-deps *.jar
效果图
按照此贴打包出完整jar -> 在JRE上试运行 -> 精简jre,然后用exe4j把 [jar] 打成exe ,再用innosetup把 [exe和JRE以及资源文件] 合成一个新的exe
如果是JDK9+,可以使用命令
教程作者说打包后,exe所在路径就是Java 的当前项目路径
其中,用于打包完整依赖的Maven插件建议用 shade,而不是作者用的那个 assembly
插件示例配置如下
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>3.2.1</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> </execution> </executions> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>com.demo.AppLauncher</mainClass> </transformer> </transformers> </configuration> </plugin>
调用该打包插件的命令:
mvn package shade:shade
在 IDEA 里配置 Java SceneBuilder
添加以下代码到start()
// for print version System.out.println(System.getProperty("java.version") +" and "+ System.getProperty("javafx.version")); // JBR = OPENJDK11.0.5 + 10.0.2-internal JavaFx //--module-path "D:\Program Files\javafx-sdk-11.0.2\lib" --add-modules=javafx.controls,javafx.fxml // Loading FXML document with JavaFX API of version 11.0.1 by JavaFX runtime of version 10.0.2-internal