Mercurial > cgi-bin > hgweb.cgi > JpegWasher
changeset 50:fb407182ba76
Add help menu item, UNTESTED.
author | David Barts <davidb@stashtea.com> |
---|---|
date | Thu, 07 May 2020 08:29:58 -0700 (2020-05-07) |
parents | 35fb8de77c7d |
children | d4ccc5ccdc6d |
files | Building.html build.xml src/name/blackcap/exifwasher/HelpDialog.kt src/name/blackcap/exifwasher/Main.kt src/name/blackcap/exifwasher/Menus.kt src/name/blackcap/exifwasher/help.html |
diffstat | 6 files changed, 109 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/Building.html Mon May 04 18:12:59 2020 -0700 +++ b/Building.html Thu May 07 08:29:58 2020 -0700 @@ -53,8 +53,7 @@ net win, as it is portable, and would spell the death of the only bit of OS-dependent Kotlin code in this application.</p> <p>In another year or two, I will probably make OpenJDK 11 or greater the - preferred version. It’s a little too early to do that right now, however, - as not many systems have Java 11 present.</p> + preferred version.</p> <h2>Build Procedure</h2> <h3>Install Prerequisites</h3> <p>See the “Prerequisites†section above for the details of what you will @@ -80,7 +79,7 @@ tools in its PATH).</p> <h3>Compile Kotlin Source and Bundle an App</h3> <p>Just type <code>ant macapp</code>, <code>ant winapp</code>, or <code>ant - deb</code> depending on whether you are building on a Mac, Windows, or + deb</code> depending on whether you are building on a Mac, Windows, or Debian Linux (note that Ubuntu is a Debian variant).</p> <h3>That’s It!</h3> <p>If all went well, a system-specific bundle should be found in the <code>dist</code>
--- a/build.xml Mon May 04 18:12:59 2020 -0700 +++ b/build.xml Thu May 07 08:29:58 2020 -0700 @@ -78,7 +78,7 @@ <!-- Define the properties used by the build --> <property name="app.name" value="${ant.project.name}"/> - <property name="app.version" value="1.03"/> + <property name="app.version" value="1.04"/> <property name="app.domain" value="name.blackcap.exifwasher"/> <property name="app.entry" value="${app.domain}.MainKt"/> <property name="app.copyright" value="Copyright © 2020, David W. Barts."/>
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/name/blackcap/exifwasher/HelpDialog.kt Thu May 07 08:29:58 2020 -0700 @@ -0,0 +1,62 @@ +/* + * The dialog that displays the Exif data in a single file (display only, + * no changing). We do this after washing. + */ +package name.blackcap.exifwasher + +import java.awt.Color +import java.awt.Dimension +import java.awt.event.ActionEvent +import java.awt.event.ActionListener +import java.io.File +import java.io.IOException +import java.io.BufferedReader +import java.io.InputStream +import java.io.InputStreamReader +import java.util.logging.Level +import java.util.logging.Logger +import javax.swing.* +import javax.swing.table.DefaultTableModel +import javax.swing.table.TableColumn +import javax.swing.table.TableColumnModel + +import name.blackcap.exifwasher.exiv2.* + +class HelpDialog : JDialog(Application.mainFrame) { + private val BW = 9 + private val BW2 = BW * 2 + private val WIDTH = 640 + private val HEIGHT = 480 + + private val dismissButton = JButton("Dismiss").also { + it.addActionListener(ActionListener { setVisible(false) }) + } + + private val helpPane = JTextPane().also { + it.contentType = "text/html"; + it.text = ::class.java.getResourceAsStream("help.html").bufferedReader().use { it.readText() } + } + + init { + setVisible(false) + title = "Help" + contentPane.apply { + layout = BoxLayout(this, BoxLayout.Y_AXIS) + add(JScrollPane(helpPane).apply { + alignmentX = JScrollPane.CENTER_ALIGNMENT + border = BorderFactory.createEmptyBorder(BW2, BW2, BW, BW2) + verticalScrollBarPolicy = ScrollPaneConstants.VERTICAL_SCROLLBAR_ALWAYS + horizontalScrollBarPolicy = ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER + preferredSize = Dimension(WIDTH, HEIGHT) + background = Application.mainFrame.background + }) + add(Box(BoxLayout.X_AXIS).apply { + alignmentX = Box.CENTER_ALIGNMENT + border = BorderFactory.createEmptyBorder(BW, BW2, BW2, BW2) + add(Box.createHorizontalGlue()) + add(dismissButton) + }) + } + pack() + } +}
--- a/src/name/blackcap/exifwasher/Main.kt Mon May 04 18:12:59 2020 -0700 +++ b/src/name/blackcap/exifwasher/Main.kt Thu May 07 08:29:58 2020 -0700 @@ -14,6 +14,7 @@ /* global UI objects */ var mainFrame: MainFrame by setOnce() var settingsDialog: SettingsDialog by setOnce() + var helpDialog: HelpDialog by setOnce() fun initialize() { UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); @@ -21,6 +22,7 @@ mainFrame.jMenuBar = MyMenuBar() setMacMenus() /* always safe to call; no-op if not a Mac */ settingsDialog = SettingsDialog() + helpDialog = HelpDialog() mainFrame.setVisible(true) } }
--- a/src/name/blackcap/exifwasher/Menus.kt Mon May 04 18:12:59 2020 -0700 +++ b/src/name/blackcap/exifwasher/Menus.kt Thu May 07 08:29:58 2020 -0700 @@ -37,11 +37,14 @@ }) } }) - if (OS.type != OS.MAC) { - add(JMenu("Help").apply { + add(JMenu("Help").apply { + if (OS.type != OS.MAC) { add(JMenuItem("About ${Application.MYNAME}…").apply { addActionListener(ActionListener { showAboutDialog() }) }) + } + add(JMenuItem("${Application.MYNAME} Help…").apply { + addActionListener(ActionListener { Application.helpDialog.setVisible(true) }) }) } }
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/name/blackcap/exifwasher/help.html Thu May 07 08:29:58 2020 -0700 @@ -0,0 +1,37 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> +<html> + <head> + <meta http-equiv="content-type" content="text/html; charset=utf-8"> + <title>JpegWasher Help</title> + </head> + <body> + <h1>JpegWasher Help</h1> + <h2>Using This Program</h2> + <p>To remove sensitive metadata from your digital photos, just drag the JPEG + file(s) containing them onto the main window of this application, or + choose <em>File… Wash</em> from the menu bar.</p> + <p>A dialog will pop up displaying the metadata in the file, with check + boxes in the leftmost column marking the data to be deleted. If you + disagree with JpegWasher’s choices, check or uncheck boxes until you are + satisfied, then click on the Wash button below. The file will then be + washed, and a new dialog will pop up displaying any remaining metadata in + the washed file.</p> + <p>The newly-washed file will have the same name as the original one, with + “_washed†appended to it; e.g. washing <code>cat.jpg</code> will result + in <code>cat_washed.jpg</code>. (Whether or not the cat enjoys being + washed is an entirely different matter.)</p> + <h2>Configuring JpegWasher</h2> + <p>This is a configurable program, whose operation may be adjusted by the + preferences dialog (accessed under the <em>JpegWasher</em> menu on the + Mac and the <em>File</em> menu on Linux and Windows).</p> + <p>The whitelist that determines which metadata keys will <em>not</em> be + deleted can be changed, via the <em>Whitelist</em> pane of the + preferences dialog. Note that there are two kinds of whitelist entries: + ones that match entire keys, and ones that match the prefixes of keys (the + latter entries end with an asterisk “*â€). Whitelist entries are case + sensitive; “exif.image.white*†will not match “Exif.Image.WhitePoint.â€</p> + <p>It is also possible to set the folder where output files are created, via + the <em>Folders</em> pane (by default, this is the same folder the input + file was in).</p> + </body> +</html>