Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Donate another batch of SVG icons #8083

Merged
merged 2 commits into from
Jan 5, 2025
Merged

Conversation

eirikbakke
Copy link
Contributor

@eirikbakke eirikbakke commented Dec 22, 2024

Here is another batch of SVG icons for NetBeans, drawn by myself. This is a continuation of the effort to make NetBeans look good on HiDPI/Retina screens (see previous PRs).

There are 99 new icons in total. Many are used in multiple places in the codebase. See this generated page for a visual summary.

Some examples:

image

image

image

Some IDE icons now have SVG icons available, but still load their old PNG versions (e.g. the lightbulb hint icons in the first screenshot above). In these cases we will need to find the place in the codebase where icon loading happens, and change it manually. Automatic loading of SVG versions only happens when icons are loaded via ImageUtilities.loadImage or loadImageIcon, rather than e.g. "new ImageIcon()" or Toolkit.getImage. Such changes are left for future work (contributions welcome!)

There is a corresponding PR to the icon-scripts tool in the netbeans-tools repo, to add the latest version of the original Adobe Illustrator file and update file that specifies the mapping from bitmap to SVG icon files.

…h the style of other NetBeans icons.

The icons for OptionPane are 32x32 pixel version of the info/error/warning/question icons (scaled up from similar 16x16 SVG icons, but maintaining the 1px border width as this looks better).

The icons for file chooser are "folder", "file", "parent folder", and "home folder".

To keep the SVG loader module optional for NetBeans Platform apps, PNG versions of the icons are used here. SVG versions will be added in a separate commit (together with a bunch of other SVG files).
@matthiasblaesing
Copy link
Contributor

I wanted to see the icons in comparison and I came up with this (PATH_TO_NETBEANS should hold the path to the NB sources, COMPARE_OUTPUT path to HTML output). The script generates a HTML file that can be opened with a browser and shows all SVG aside the PNG/GIF base.

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.stream.Stream;


public class GenerateComparison {
    public static void main(String[] args) throws IOException {
        String PATH_TO_NETBEANS = "";
        String COMPARE_OUTPUT = "";
        Path basePath = Paths.get(PATH_TO_NETBEANS);
        try (Stream<Path> pathStream = Files.walk(basePath);
                FileOutputStream fos = new FileOutputStream(COMPARE_OUTPUT);
                OutputStreamWriter osw = new OutputStreamWriter(fos, StandardCharsets.UTF_8)) {
            osw.write(
                """
                <html>
                    <head>
                        <title></title>
                    </head>
                    <body>
                    <table>
                        <tr>
                            <th>Path</th>
                            <th>SVG</th>
                            <th>PNG/GIF</th>
                        </tr>
                """
            );
            pathStream
                    .filter(p -> p.getFileName().toString().endsWith(".svg"))
                    .forEach(svgPath -> {
                        try {
                            Path relativePath = basePath.relativize(svgPath);
                            Path directory = svgPath.getParent();
                            String svgFilename = svgPath.getFileName().toString();
                            String pngFilename = svgFilename.replaceAll("\\.svg$", ".png");
                            String gifFilename = svgFilename.replaceAll("\\.svg$", ".gif");
                            Path pngPath = directory.resolve(pngFilename);
                            Path gifPath = directory.resolve(gifFilename);
                            if (Files.isReadable(pngPath) || Files.isReadable(gifPath)) {
                                osw.write("<tr>");
                                osw.write("<td>");
                                osw.write(relativePath.toString());
                                osw.write("</td>");
                                osw.write("<td>");
                                osw.write("<img src='");
                                osw.write(svgPath.toUri().toASCIIString());
                                osw.write("' height='16' width='16' />");
                                osw.write("</td>");
                                osw.write("<td>");
                                if (Files.isReadable(pngPath)) {
                                    osw.write("<img src='");
                                    osw.write(pngPath.toUri().toASCIIString());
                                    osw.write("' height='16' width='16' />");
                                }
                                if (Files.isReadable(gifPath)) {
                                    osw.write("<img src='");
                                    osw.write(gifPath.toUri().toASCIIString());
                                    osw.write("' height='16' width='16' />");
                                }
                                osw.write("</td>");
                                osw.write("</tr>");
                            }
                        } catch (IOException ex) {
                            Logger.getLogger(GenerateComparison.class.getName()).log(Level.SEVERE, null, ex);
                        }
                    });
            osw.write(
                """
                    </table>
                    </body>
                </html>
                """
            );
        }
    }
}

@eirikbakke
Copy link
Contributor Author

eirikbakke commented Dec 28, 2024

Thanks for that; the script works when I tested it!

There is also a HTML page summary called "icons.html" in the NetBeans root directory in this PR. There's an online version of the same file at https://people.csail.mit.edu/ebakke/misc/netbeans-icons-241222.html

That one is generated by the script in https://github.com/apache/netbeans-tools/tree/master/icon-scripts

(Though it's good to have the changes verified with a second script that takes data straight from the source repo only, as opposed to the mappings and hash files used by icon-scripts.)

@matthiasblaesing
Copy link
Contributor

So I looked through the comparison and in general these look like good updates, even for non-hidpi. The following icons caught my attention:

  • java/refactoring.java/src/org/netbeans/modules/refactoring/java/resources/filterHideStatic.svg looks generally broken:
    grafik
  • From context java/java.source/src/org/netbeans/modules/java/source/resources/icons/initializer.svg should look different to java/java.source/src/org/netbeans/modules/java/source/resources/icons/constructorPublic.svg and if that is agreed on, java/java.source/src/org/netbeans/modules/java/source/resources/icons/initializerStatic.svg should also be updated, to follow the style change
    grafik
    grafik
    grafik
  • The icons java/maven.repository/src/org/netbeans/modules/maven/repository/localrepo.svg and java/maven.repository/src/org/netbeans/modules/maven/repository/remoterepo.svg should have different visualization as they are used to discern local from remote repo.
    grafik

Thank you for your work!

@eirikbakke
Copy link
Contributor Author

Thank you for reviewing the mappings!

In the filterHideStatic case, I think see two variations of icons with this name: the simple vertical blue bar (image) and a more elaborate version with the character "s" included (image). Since the icons had the same name I assumed they are supposed to represent the same thing, and that the vertical bar is a newer simplified version. (There's a whole visual language invented by the original designer, where vertical bar means static, blue square means field etc.)

image

So for this one I'd be inclined to keep the current mapping to the simple vertical bar for all of them. Alternatively I could exclude the two icons that have the more elaborate design.

From context java/java.source/src/org/netbeans/modules/java/source/resources/icons/initializer.svg should look different to java/java.source/src/org/netbeans/modules/java/source/resources/icons/constructorPublic.svg

Ah, I see the hollowed-out diamonds (imageimage) might be intended to distinguish initializers from constructors. But grepping through the source code, it seems the hollowed-out versions of the two icons are never actually used anywhere. Did you observe them somewhere in the GUI?

image

The icons java/maven.repository/src/org/netbeans/modules/maven/repository/localrepo.svg and java/maven.repository/src/org/netbeans/modules/maven/repository/remoterepo.svg should have different visualization as they are used to discern local from remote repo.

You're right! Will fix that. In fact, I think "repo" (imageimage) should be separate from "database" (image). I'll make separate icons for those (different color, no platter bars).

eirikbakke added a commit to eirikbakke/netbeans-tools that referenced this pull request Jan 4, 2025
There are now separate 'database', 'localRepo', and 'remoteRepo' icons.

(There is a corresponding new commit in apache/netbeans#8083 .)
@eirikbakke
Copy link
Contributor Author

I added another commit with a few more icons (libraries, librariesBadge8x8, logicalView, fileView, fileImage, executableBadge, localRepo, remoteRepo).

As suggested, there are now separate icons for "localRepo" (image) and "remoteRepo" (image), and I've made them distinct from "database" (image).

There's an updated summary page at https://people.csail.mit.edu/ebakke/misc/netbeans-icons-250104.html , and a corresponding new commit to apache/netbeans-tools#73.

Copy link
Contributor

@matthiasblaesing matthiasblaesing left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for the update. I agree, that the unification for filterHideStatic makes sense. I also agree with the updated icons for the repo.

For the initializer* icons: Agreed, I also don't find usages, I think though, that it would be good if the SVG variant follows the PNG if that is not a problem. If you agree, that would be great, if not this is still great work and I think good to go.

@eirikbakke
Copy link
Contributor Author

Thanks!

For the initializer* icons: Agreed, I also don't find usages, I think though, that it would be good if the SVG variant follows the PNG if that is not a problem.

Looking at this again, the hollow vs. non-hollow variations don't seem to follow a consistent pattern, so I'd be inclined to consider the difference semantically insignificant, and keep mapping them to the same artboard name (and thus SVG file). If we wanted separate artboard mappings, it's not clear what they would be named. For example:

  • There are both hollow (image) and non-hollow (image) PNG icons called "initializerStatic.png".
  • A non-hollow PNG icon (image) exists both with the name "constructorPublic.png" and "initializer.png".

I think there might at some point have been an intention to distinguish constructors and initializers, but it was not done consistently. And it may not have mattered in the end, since e.g. the Navigator does not seem to show an entry for initializers.

@matthiasblaesing
Copy link
Contributor

Sorry, I did not notice the existing inconsistency. Lets keep as is then. Thanks for seeing this through.

…on of the effort to make NetBeans look good on HiDPI/Retina screens.

There are 107 new icons in total, copied into many more places where duplicate bitmap icons were identified. Some existing icons were also adjusted, and some existing icons were copied into new locations where additional duplicates were identified.

I prioritized icons that are commonly seen in the IDE, and which happen to be easy to draw, as well as icons that are similar to already-drawn ones or simple variations or combinations thereof.

The changes in this commit consist purely of copying SVG files into various locations in the repo; this was done by the hidpi-icons script at https://github.com/apache/netbeans-tools/tree/master/icon-scripts/hidpi-icons . I will open a separate Pull Request for that repo, to update the Adobe Illustrator file and icon mapping files.

The 'icons.html' file that is generated by the hidpi-icons script is now included as part of the commit, in the root of the NetBeans repo. It includes a preamble with useful information and links to the README.
@eirikbakke
Copy link
Contributor Author

I squashed the last two commits in anticipation of merging. I'll leave the first commit separate (OptionPane FlatLAF customizations).

eirikbakke added a commit to eirikbakke/netbeans-tools that referenced this pull request Jan 5, 2025
…s to artboard names and SVG files.

Reorder some of the mappings to keep similar-looking icons together in the generated icons.html file.

Icon script improvements:
* Allow SVG paths to be included in mappings.tsv, for new icons that do not have a corresponding PNG or GIF file. (Did not end up using this feature currently. But it might be useful in the future.)
* Permit a subset of SVG files to be copied into the NetBeans repo, depending on what files exist in the illustrator_exports folder.
* Add an explanatory preamble to the generated icons.html file, with links to the README and other relevant information.
* In the generated icons.html, sort unassigned bitmap icons by first path observed. (Help keeps related icons together.)

This commit corresponds to the changes in apache/netbeans#8083, including the final PR revisions.
@eirikbakke eirikbakke merged commit 5ded943 into apache:master Jan 5, 2025
32 checks passed
eirikbakke added a commit to apache/netbeans-tools that referenced this pull request Jan 5, 2025
…s to artboard names and SVG files.

Reorder some of the mappings to keep similar-looking icons together in the generated icons.html file.

Icon script improvements:
* Allow SVG paths to be included in mappings.tsv, for new icons that do not have a corresponding PNG or GIF file. (Did not end up using this feature currently. But it might be useful in the future.)
* Permit a subset of SVG files to be copied into the NetBeans repo, depending on what files exist in the illustrator_exports folder.
* Add an explanatory preamble to the generated icons.html file, with links to the README and other relevant information.
* In the generated icons.html, sort unassigned bitmap icons by first path observed. (Help keeps related icons together.)

This commit corresponds to the changes in apache/netbeans#8083, including the final PR revisions.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Look and Feel Platform [ci] enable platform tests (platform/*) UI User Interface
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants