Retired Document
Important: This document may not represent best practices for current development. Links to downloads and other resources may no longer be valid.
MRJAppBuilder Tutorial
Although command-line Java applications are great for development, when you want to distribute your application, you want the user to be able to launch it just like any other Mac OS X application—without a trip to the command line. MRJAppBuilder allows you to take your existing Java .class
or .jar
files and wrap them into a Mac OS X application bundle. This chapter provides a simple tutorial that you can work through to help you understand this process.
To follow this example, you need to have the Mac OS X Developer Tools installed. MRJAppBuilder is installed in /Developer/Applications
. The sourcecode files you need are ExampleFileFilter.java
, ExampleFileView.java
, and FileChooserDemo.java
; they are installed in /Developer/Examples/Java/JFC
/FileChooserDemo/src. If you do not see these files, install the Mac OS X Developer Tools. If you do a custom install, make sure that the Developer Example and Developer Tools Software packages are installed. This example will take a JAR file and show you how to bundle it as a Mac OS X application.
Building a Basic Application
MRJAppBuilder works with either stand-alone class files or class files in a JAR file. Since most of the source code in /Developer/Examples/Java
is not compiled, the first step is to compile a selection to obtain the class files.
In this example, you will use the FileChooserDemo application. From Terminal, compile the three Java files in /Developer/Examples/Java/JFC/FileChooserDemo/src
with javac -d /tmp /Developer/Examples/Java/JFC/FileChooserDemo/src/*.java
. This gives you the required class files.
Once you have the class files, open the MRJAppBuilder application in /Developer/Applications
. When the application opens, you are presented with the Application pane. The required fields for building a valid application are all present in this pane.
In this example set the main classname to FileChooserDemo. This is the class that contains the main
method. Set the classpath to /tmp
. In this example, there are only class files in the classpath. It might be appropriate in a more complicated application for the classpath to include image, font, or sound files as well. Set the output file to whatever location is convenient to use for testing your application. This field should include the fully qualified intended location and name of the resultant application, for example /tmp/FileChooserDemo.app
. Be sure to append the .app
suffix to the name you choose for this application. The result should be similar to Figure B-1.
data:image/s3,"s3://crabby-images/94cc6/94cc6140d0a06a420e36e488f477300d1ec055a5" alt="MRJAppBuilder Application pane"
With these three fields filled in, you are ready to build the application. Click the Build Application button. You are informed that your build was successful.
data:image/s3,"s3://crabby-images/98729/98729cbc929934ebea874d6fcc6c3b200b57bf78" alt="A successful build"
Navigating in the Finder to the directory you specified in the “Output file” field reveals a double-clickable application. (Hint: In Finder, choose Go to Folder from the Go menu.)
Building a More Robust Application
The example in Building a Basic Application worked fine, but notice that you set the path to a specific directory, /tmp
. Unless your users happen to have the appropriate class files installed in /tmp
, this application won’t work on their computers. How do you get around this? That leads to another pane in MRJAppBuilder. Before using it though you need to prepare the appropriate files. In this example, navigate to your /tmp
directory and make a JAR file from the class files you put there as follows:
jar cf FileChooserDemo.jar *.class |
You should still have MRJAppBuilder open. If not go ahead and open it and set it up the way it was before. Click the tab labeled Merge Files. It gives you the option to add files. Click the Add button and choose the JAR file you just made. The result should look like Figure B-3.
data:image/s3,"s3://crabby-images/740ec/740ec869104f71f3e1664e0bc55d6aade2167d7f" alt="Merge Files pane"
The JAR file is copied into the /Contents/Resources/Java
directory of the resulting application bundle. Now go back to the Application pane. Notice that the path to this JAR file was automatically added to the /tmp
path you had there before. (You can get rid of that reference to /tmp
now if you haven’t already.) You now have a Mac OS X application that a user can install by simply dropping in the Finder without having to deal with installing anything else or being concerned with where the application is installed.
Making Your Application More Mac-like
So far you have built a basic application that has some features that Mac users expect. For example they can install it with a simple drag and drop. If you launch that application, you will notice something missing. The icon in the Dock is a generic Java icon. You can fix that easily enough in MRJAppBuilder. For the sake of this example, just copy an icon from another application, in this case the icon from the prebuilt version of the FileChooserDemo application. To do this, select the generic icon in the Application pane. It is near the bottom of the pane, in the “Output file” section. If you click it, it opens a file chooser. Navigate to the file named JavaApp.icns
in /Developer/Examples/Java/JFC/FileChooserDemo/FileChooserDemo.app/Contents/Resources
and click Select. (You will probably need to change the Format pop-up menu to All Files from the default Icon Files to navigate there.) Now if you build the application, you should see that it displays the new icon in the Dock.
Java Properties Pane
An icon is only the first step. There are a few other things you can do to make a well-written Java application hard to distinguish from a native Mac OS X application. MRJAppBuilder provides an interface for making a lot of these changes in the Java Properties pane. Before going there, launch the FileChooserDemo application that you just built. Notice that the window has a white bar at the bottom of the window as shown in Figure B-4.
data:image/s3,"s3://crabby-images/2e6fc/2e6fcc05f33bd46937dc2d8d399d28f8e59a22bc" alt="FileChooserDemo application with relics"
This is because by default, MRJAppBuilder sets certain system properties. In this case, com.apple.mrj.application.growbox.intrudes
is set to false
. The result is that an extra 15 pixels are added to the window. You can correct this in the Java Properties pane.
Click the Java Properties tab. This pane contains properties that are passed to the application when it is run. Of special note here is the Parameters property. This is where you can specify any command-line parameters that need to be passed to your application when it is run. To see the effect of modifying the Java properties, change the value of the growbox.intrudes
property from false
to true
as in Figure B-5.
growbox.intrudes
propertydata:image/s3,"s3://crabby-images/80571/805710ad800ada06954252d2ce75db8af451d625" alt="Modifying the growbox.intrudes property"
Quit the previously built FileChooserDemo if it is still running, and build and run the new version. Notice that the relics no longer surround the window when you switch between the different interface styles.
com.apple.mrj.application.growbox.intrudes=true
data:image/s3,"s3://crabby-images/fa86b/fa86b2cf9f491c81cc0201a2eb2836dc7392d4bd" alt="com.apple.mrj.application.growbox.intrudes=true"
You can change the value of the other properties by clicking the appropriate value field and making the desired change. See Appendix C, Mac OS X Java System Properties, for a listing and description of some Mac OS X system properties.
Mac OS X Pane
The Mac OS X pane allows you to set attributes of the Mac OS X application bundle. Features like the application icon and name can be set here. For information on these keys and how to use them, see Mac Technology Overview . These are not explored in this tutorial.
In this tutorial, you have seen how to wrap your JAR files into a native Mac OS X application, and you have seen how to modify the parameters of that application to build an application that fits in with the native applications in Mac OS X. There was no magic going on behind the scenes. MRJAppBuilder is a very simple application that builds an application bundle directory structure, determines runtime options to be passed to the Java virtual machine when the application is invoked, and sets some Mac OS X application properties. To get a glimpse inside an application in Mac OS X, you can either explore the directory of the .app
from the Terminal or from the Finder. To see what is contained inside an application bundle generated by MRJAppBuilder, Control-click an MRJAppBuilder-generated application. You could use the FileChooserDemo application or even MRJAppBuilder itself. Inside is a structure similar to Figure B-7
data:image/s3,"s3://crabby-images/814ce/814ced5e61d9d74a8c91330240d355735b62de2e" alt="Application bundle contents"
Once you have built an application bundle with MRJAppBuilder, you might want to fine tune the settings in the Info.plist
or the MRJApp.properties
files by hand. Any text editor will do and you won’t need to set up all of the fields in MRJAppBuilder each time you want to make changes.
Copyright © 2002 Apple Computer, Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2002-09-01