Skip to content

Commit 6c8d0e6

Browse files
author
Alexander Zuev
committedJul 18, 2022
8282526: Default icon is not painted properly
Reviewed-by: aivanov, prr
1 parent e72742e commit 6c8d0e6

File tree

3 files changed

+98
-4
lines changed

3 files changed

+98
-4
lines changed
 

‎src/java.desktop/windows/classes/sun/awt/shell/Win32ShellFolder2.java

+13-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2003, 2022, Oracle and/or its affiliates. All rights reserved.
33
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44
*
55
* This code is free software; you can redistribute it and/or modify it
@@ -25,7 +25,9 @@
2525

2626
package sun.awt.shell;
2727

28+
import java.awt.Graphics2D;
2829
import java.awt.Image;
30+
import java.awt.RenderingHints;
2931
import java.awt.image.AbstractMultiResolutionImage;
3032
import java.awt.image.BufferedImage;
3133
import java.awt.image.ImageObserver;
@@ -1421,7 +1423,7 @@ protected Image getBaseImage() {
14211423
public Image getResolutionVariant(double width, double height) {
14221424
int dist = 0;
14231425
Image retVal = null;
1424-
// We only care about width since we don't support non-rectangular icons
1426+
// We only care about width since we don't support non-square icons
14251427
int w = (int) width;
14261428
int retindex = 0;
14271429
for (Integer i : resolutionVariants.keySet()) {
@@ -1435,6 +1437,15 @@ public Image getResolutionVariant(double width, double height) {
14351437
}
14361438
}
14371439
}
1440+
if (retVal.getWidth(null) != w) {
1441+
BufferedImage newVariant = new BufferedImage(w, w, BufferedImage.TYPE_INT_ARGB);
1442+
Graphics2D g2d = newVariant.createGraphics();
1443+
g2d.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BICUBIC);
1444+
g2d.drawImage(retVal, 0,0, w, w, null);
1445+
g2d.dispose();
1446+
resolutionVariants.put(w, newVariant);
1447+
retVal = newVariant;
1448+
}
14381449
return retVal;
14391450
}
14401451

‎src/java.desktop/windows/native/libawt/windows/ShellFolder2.cpp

+12-2
Original file line numberDiff line numberDiff line change
@@ -980,10 +980,20 @@ JNIEXPORT jlong JNICALL Java_sun_awt_shell_Win32ShellFolder2_extractIcon
980980
UINT uFlags = getDefaultIcon ? GIL_DEFAULTICON : GIL_FORSHELL | GIL_ASYNC;
981981
hres = pIcon->GetIconLocation(uFlags, szBuf, MAX_PATH, &index, &flags);
982982
if (SUCCEEDED(hres)) {
983+
UINT iconSize;
984+
HICON hIconSmall;
983985
if (size < 24) {
984-
size = 16;
986+
iconSize = (size << 16) + 32;
987+
} else {
988+
iconSize = (16 << 16) + size;
989+
}
990+
hres = pIcon->Extract(szBuf, index, &hIcon, &hIconSmall, iconSize);
991+
if (size < 24) {
992+
fn_DestroyIcon((HICON)hIcon);
993+
hIcon = hIconSmall;
994+
} else {
995+
fn_DestroyIcon((HICON)hIconSmall);
985996
}
986-
hres = pIcon->Extract(szBuf, index, &hIcon, NULL, size);
987997
} else if (hres == E_PENDING) {
988998
pIcon->Release();
989999
return E_PENDING;
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,73 @@
1+
/*
2+
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation.
8+
*
9+
* This code is distributed in the hope that it will be useful, but WITHOUT
10+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12+
* version 2 for more details (a copy is included in the LICENSE file that
13+
* accompanied this code).
14+
*
15+
* You should have received a copy of the GNU General Public License version
16+
* 2 along with this work; if not, write to the Free Software Foundation,
17+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18+
*
19+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20+
* or visit www.oracle.com if you need additional information or have any
21+
* questions.
22+
*/
23+
24+
import javax.swing.Icon;
25+
import javax.swing.ImageIcon;
26+
import javax.swing.filechooser.FileSystemView;
27+
import java.awt.Image;
28+
import java.awt.image.MultiResolutionImage;
29+
import java.io.File;
30+
import java.io.IOException;
31+
32+
/*
33+
* @test
34+
* @bug 8282526
35+
* @summary Default icon is not painted properly
36+
* @requires (os.family == "windows")
37+
* @run main WindowsDefaultIconSizeTest
38+
*/
39+
40+
public class WindowsDefaultIconSizeTest {
41+
public static void main(String[] args) {
42+
WindowsDefaultIconSizeTest test = new WindowsDefaultIconSizeTest();
43+
test.test();
44+
}
45+
46+
public void test() {
47+
String sep = System.getProperty("file.separator");
48+
String dir = System.getProperty("test.src", ".");
49+
String filename = "test.not";
50+
51+
File testFile = new File(dir + sep + filename);
52+
try {
53+
if (!testFile.exists()) {
54+
testFile.createNewFile();
55+
testFile.deleteOnExit();
56+
}
57+
FileSystemView fsv = FileSystemView.getFileSystemView();
58+
Icon icon = fsv.getSystemIcon(new File(dir + sep + filename));
59+
if (icon instanceof ImageIcon) {
60+
Image image = ((ImageIcon) icon).getImage();
61+
if (image instanceof MultiResolutionImage) {
62+
Image variant = ((MultiResolutionImage) image).getResolutionVariant(16, 16);
63+
if (variant.getWidth(null) != 16) {
64+
throw new RuntimeException("Default file icon has size of " +
65+
variant.getWidth(null) + " instead of 16");
66+
}
67+
}
68+
}
69+
} catch (IOException ioe) {
70+
throw new RuntimeException("Unexpected error while creating the test file: " + ioe.getLocalizedMessage());
71+
}
72+
}
73+
}

0 commit comments

Comments
 (0)
Please sign in to comment.