org.icepdf.ri.viewer.Launcher Maven / Gradle / Ivy
/*
* Copyright 2006-2019 ICEsoft Technologies Canada Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an "AS
* IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
package org.icepdf.ri.viewer;
import org.icepdf.core.util.Defs;
import org.icepdf.core.util.SystemProperties;
import org.icepdf.ri.common.ViewModel;
import org.icepdf.ri.util.FontPropertiesManager;
import org.icepdf.ri.util.URLAccess;
import org.icepdf.ri.util.ViewerPropertiesManager;
import javax.swing.*;
import java.text.MessageFormat;
import java.util.ResourceBundle;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.prefs.Preferences;
/**
* Launches the Viewer Application. The following parameters can be used
* to optionally load a PDF document at startup.
*
*
* Option
* Description
*
*
* -loadfile filename
* Starts the ICEpdf Viewer and displays the specified local PDF file.
* Use the following syntax:
* -loadfile c:/examplepath/file.pdf
*
*
* -loadfile filename
* Starts the ICEpdf Viewer and displays the PDF file at the specified
* URL. Use the following syntax:
* -loadurl http://www.examplesite.com/file.pdf
*
*
*/
public class Launcher {
private static final Logger logger =
Logger.getLogger(Launcher.class.toString());
public static final String APPLICATION_LOOK_AND_FEEL = "application.lookandfeel";
// stores properties used by ICEpdf
private static ViewerPropertiesManager propertiesManager;
public static void main(String[] argv) {
boolean brokenUsage = false;
String contentURL = "";
String contentFile = "";
String printer = null;
// parse command line arguments
for (int i = 0; i < argv.length; i++) {
if (i == argv.length - 1) { //each argument requires another
brokenUsage = true;
break;
}
String arg = argv[i];
switch (arg) {
case "-loadfile":
contentFile = argv[++i].trim();
break;
case "-loadurl":
contentURL = argv[++i].trim();
break;
case "-print":
printer = argv[++i].trim();
break;
default:
brokenUsage = true;
break;
}
}
// load message bundle
ResourceBundle messageBundle = ResourceBundle.getBundle(
ViewerPropertiesManager.DEFAULT_MESSAGE_BUNDLE);
// Quit if there where any problems parsing the command line arguments
if (brokenUsage) {
System.out.println(messageBundle.getString("viewer.commandLin.error"));
System.exit(1);
}
// start the viewer
run(contentFile, contentURL, printer, messageBundle);
}
/**
* Starts the viewer application.
*
* @param contentFile URI of a file which will be loaded at runtime, can be
* null.
* @param contentURL URL of a file which will be loaded at runtime, can be
* null.
* @param printer The name of the printer to use, can be null
* @param messageBundle messageBundle to pull strings from
*/
private static void run(String contentFile,
String contentURL,
String printer,
ResourceBundle messageBundle) {
// initiate the properties manager.
propertiesManager = ViewerPropertiesManager.getInstance();
// initiate font Cache manager, reads system if necessary, load the cache otherwise.
FontPropertiesManager.getInstance().loadOrReadSystemFonts();
// set look & feel
setupLookAndFeel(messageBundle);
ViewModel.setDefaultFilePath(propertiesManager.getPreferences().get(
ViewerPropertiesManager.PROPERTY_DEFAULT_FILE_PATH, null));
ViewModel.setDefaultURL(propertiesManager.getPreferences().get(
ViewerPropertiesManager.PROPERTY_DEFAULT_URL, null));
// application instance
WindowManager windowManager = WindowManager.createInstance(propertiesManager, messageBundle);
if (contentFile != null && !contentFile.isEmpty()) {
if (printer != null) {
windowManager.newWindow(contentFile, printer);
} else {
windowManager.newWindow(contentFile);
}
ViewModel.setDefaultFilePath(contentFile);
}
// load a url if specified
if (contentURL != null && !contentURL.isEmpty()) {
URLAccess urlAccess = URLAccess.doURLAccess(contentURL);
urlAccess.closeConnection();
if (urlAccess.errorMessage != null) {
// setup a patterned message
Object[] messageArguments = {urlAccess.errorMessage,
urlAccess.urlLocation
};
MessageFormat formatter = new MessageFormat(
messageBundle.getString("viewer.launcher.URLError.dialog.message"));
JOptionPane.showMessageDialog(
null,
formatter.format(messageArguments),
messageBundle.getString("viewer.launcher.URLError.dialog.title"),
JOptionPane.INFORMATION_MESSAGE);
} else {
if (printer != null) {
windowManager.newWindow(urlAccess.url, printer);
} else {
windowManager.newWindow(urlAccess.url);
}
}
ViewModel.setDefaultURL(urlAccess.urlLocation);
urlAccess.dispose();
}
// Start an empy viewer if there was no command line parameters
if (((contentFile == null || contentFile.isEmpty()) &&
(contentURL == null || contentURL.isEmpty()))
|| (windowManager.getNumberOfWindows() == 0)
) {
windowManager.newWindow("");
}
}
/**
* If a L&F has been specifically set then try and use it. If not
* then resort to the 'native' system L&F.
*
* @param messageBundle application message bundle
*/
private static void setupLookAndFeel(ResourceBundle messageBundle) {
// Do Mac related-setup (if running on a Mac)
if (SystemProperties.OS_NAME.contains("OS X")) {
// Running on a mac
// take the menu bar off the jframe
Defs.setSystemProperty("apple.laf.useScreenMenuBar", "true");
// set the name of the application menu item (must precede the L&F setup)
String appName = messageBundle.getString("viewer.window.title.default");
Defs.setSystemProperty("com.apple.mrj.application.apple.menu.about.name", appName);
}
Preferences preferences = propertiesManager.getPreferences();
String className =
propertiesManager.getLookAndFeel(APPLICATION_LOOK_AND_FEEL,
null, messageBundle);
if (className != null) {
try {
UIManager.setLookAndFeel(className);
return;
} catch (Exception e) {
// setup a patterned message
Object[] messageArguments = {
preferences.get(APPLICATION_LOOK_AND_FEEL, null)
};
MessageFormat formatter = new MessageFormat(
messageBundle.getString("viewer.launcher.URLError.dialog.message"));
// Error - unsupported L&F (probably windows)
JOptionPane.showMessageDialog(
null,
formatter.format(messageArguments),
messageBundle.getString("viewer.launcher.lookAndFeel.error.message"),
JOptionPane.ERROR_MESSAGE);
}
}
try {
String defaultLF = UIManager.getSystemLookAndFeelClassName();
UIManager.setLookAndFeel(defaultLF);
} catch (Exception e) {
logger.log(Level.FINE, "Error setting Swing Look and Feel.", e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy