我被扔进了一个现有的软件开发项目,该项目在NetBeansJava项目中使用Maven。
我已经将源代码从祝福的 git 存储库中获取到新安装的 NetBeans 8 中。如果我构建并运行它,它就会运行。:-)
我必须编辑使用 NetBeans GUI 生成器创建的程序的 GUI。如果我尝试打开 GUI 编辑器,它总是将一些extends JXPanel
的组件标记为无效,因为以下错误:
java.lang.NoClassDefFoundError: org/jdesktop/swingx/JXPanel...由java.lang.ClassNotFoundException引起的:org.jdesktop.swingx.JXPanel
我根本不明白 - 文件swingx-1.6.jar和swingx-beaninfo-1.6.jar位于项目的依赖项部分(没有"!"),我已将它们添加到库管理器中,并将它们添加到Palette中。程序运行,但为什么,为什么,为什么 NetBeans GUI 编辑器找不到类?
我做错了什么?
以下摘自pom.xml:
<dependency>
<groupId>org.jdesktop</groupId>
<artifactId>swingx</artifactId>
<version>1.6</version>
<scope>system</scope>
<systemPath>${basedir}/lib/swingx-1.6.jar</systemPath>
</dependency>
<dependency>
<groupId>org.jdesktop</groupId>
<artifactId>swingx.beaninfo</artifactId>
<scope>system</scope>
<version>1.6</version>
<systemPath>${basedir}/lib/swingx-beaninfo-1.6.jar</systemPath>
</dependency>
我建议您使用来自中央 maven 存储库的 swingx 而不是您的本地副本 - 我怀疑存在错误或 GUI 编辑器无法解析 ${basedir}。这是我的设置,效果很好:
<dependencies>
<dependency>
<groupId>org.swinglabs.swingx</groupId>
<artifactId>swingx-all</artifactId>
<version>1.6.5</version>
</dependency>
</dependencies>
和相应的 Java 类:
public class NewJFrame extends javax.swing.JFrame {
/**
* Creates new form NewJFrame
*/
public NewJFrame() {
initComponents();
}
/**
* This method is called from within the constructor to initialize the form.
* WARNING: Do NOT modify this code. The content of this method is always
* regenerated by the Form Editor.
*/
@SuppressWarnings("unchecked")
// <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
private void initComponents() {
jXPanel1 = new org.jdesktop.swingx.JXPanel();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
jXPanel1.setBackground(new java.awt.Color(153, 204, 255));
javax.swing.GroupLayout jXPanel1Layout = new javax.swing.GroupLayout(jXPanel1);
jXPanel1.setLayout(jXPanel1Layout);
jXPanel1Layout.setHorizontalGroup(
jXPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGap(0, 259, Short.MAX_VALUE)
);
jXPanel1Layout.setVerticalGroup(
jXPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGap(0, 171, Short.MAX_VALUE)
);
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
getContentPane().setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addContainerGap()
.addComponent(jXPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addContainerGap(131, Short.MAX_VALUE))
);
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addContainerGap()
.addComponent(jXPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addContainerGap(118, Short.MAX_VALUE))
);
pack();
}// </editor-fold>//GEN-END:initComponents
/**
* @param args the command line arguments
*/
public static void main(String args[]) {
/* Set the Nimbus look and feel */
//<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
/* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
* For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html
*/
try {
for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
if ("Nimbus".equals(info.getName())) {
javax.swing.UIManager.setLookAndFeel(info.getClassName());
break;
}
}
} catch (ClassNotFoundException ex) {
java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (InstantiationException ex) {
java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (IllegalAccessException ex) {
java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
} catch (javax.swing.UnsupportedLookAndFeelException ex) {
java.util.logging.Logger.getLogger(NewJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
}
//</editor-fold>
/* Create and display the form */
java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
new NewJFrame().setVisible(true);
}
});
}
// Variables declaration - do not modify//GEN-BEGIN:variables
private org.jdesktop.swingx.JXPanel jXPanel1;
// End of variables declaration//GEN-END:variables
}
我现在修复了它 - 感谢@Asprise支持,他把我推向了正确的方向。
问题似乎是马蒂斯确实无法处理pom中的<systemPath>${basedir}/...
条目.xml确实如此。
因此,唯一要做的就是从存储库加载依赖项。如果它们已经在某个存储库中:太好了。如果没有,请创建自己的本地并引用它:
- 在项目中创建一个存储库目录,例如
maven-repo
- 将罐子部署到其中:
mvn deploy:deploy-file -Durl=file://<absolute-path-to-repo> -Dfile=<path-to-jar> -DgroupId=<groupId-from-pom.xml> -DartifactId=<artifactId-from-pom.xml> -Dpackaging=jar -Dversion=<version-from-pom.xml>
-
将新存储库添加到 pom.xml:
<repositories> <repository> <id>someGreatName</id> <url>file://${basedir}/theNameOfYourRepositoryFolder</url> </repository> </repositories>
(最后两步来自 https://devcenter.heroku.com/articles/local-maven-dependencies)
- 可以肯定的是,清空位于
~/.m2/repository
或C:Users<yourUserName>.m2repository
的本地Maven缓存 - 启动应用程序,让 Maven 下载所有依赖项。
应该可以工作了——它也不理解 pom 中的新${basedir}
.xml但 Maven 可以,之后 Matisse 从 Maven 的缓存中获取依赖项(恕我直言)。