All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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.

* * * * * * * * * * * * * *
OptionDescription
-loadfile filenameStarts the ICEpdf Viewer and displays the specified local PDF file. * Use the following syntax:
* -loadfile c:/examplepath/file.pdf
-loadfile filenameStarts 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