所以我有SparkleAcrivator类
public class SparkleActivator {
private static boolean sparkleLibLoaded = false;
//private String downloadLink;
private String menuItemTitle;
public native static void initSparkle(String pathToSparkleFramework,
boolean updateAtStartup,
int checkInterval,
/*String downloadLink,*/
String menuItemTitle);
private boolean updateAtStartup = true;
private int checkInterval = 86400;
public SparkleActivator(/*String downloadLink, */String menuItemTitle) {
//this.downloadLink = downloadLink;
this.menuItemTitle = menuItemTitle;
}
public void start() throws Exception {
try {
if(!SparkleActivator.sparkleLibLoaded) {
System.loadLibrary("sparkle_init");
SparkleActivator.sparkleLibLoaded = true;
}
} catch (Exception ex) {
ex.printStackTrace();
return;
}
initSparkle(System.getProperty("user.dir") + "/../../Frameworks/Sparkle.framework",
updateAtStartup, checkInterval, /*downloadLink, */menuItemTitle);
}
}
我启动独立应用程序并使用Sparkle
的主要类public static void main(final String... args) {
if (Helper.isOsx()) {
try {
sparkleActivator.start();
} catch (Exception e) {
new ExceptionHandler(true, 19).handleException(new NotFountSparkleInitException());
return;
}
SwingUtilities.invokeLater(new Runnable() {
public void run() {
initApp();
}
});
}
else {
}
问题是Sparkle和我的应用程序几乎同时启动,但我需要等待Sparkle窗口中的用户操作,然后启动我的应用程序。
感谢您的帮助。
答案 0 :(得分:0)
我们所知道的是Sparkle更新程序requires to be called on the main thread(即GUI线程)。因此,您的应用需要运行才能调用它。我不认为有一个明显的方法可以解决这个问题。然而,...
您可以解决问题的一种方法是将应用的可见性设置为false,直到用户完成与更新程序的交互。
例如,您可以添加活动listener to your JNI或add listeners to your updater thread。但是,线程上的侦听器需要返回用户操作而不是完成时。