当前位置: 首页 > 面试题库 >

JFrame过渡效果-当调用setState(Frame.ICONIFIED)时,它仅进入任务栏而没有动画

袁飞鹏
2023-03-14
问题内容

我现在有一个问题-当我frame.setState(Frame.ICONIFIED)使用自定义按钮进行调用(我没有使用默认的JFrame最小化按钮-
JFrame设置为setUndecorated(true))时,JFrame进入了任务栏,而没有任何动画。在正常情况下,应逐步将任务栏最小化。但是,如果我在任务栏上按下图标化的JFrame,它会随着动画恢复到正常大小。这种情况出现在Windows
XP上,未经其他系统测试,但是我想它的行为方式相同。


问题答案:

如果您说的是真的,则单击任务栏中的图标时,未修饰的窗口实际上会动画。然后,您可以使用JNA在代码中触发相同的操作。

为了使该解决方案有效,您需要在类路径中包含jna.jar和jna

-platform.jar。

这不是JNA教程,周围有很多内容。这只是使用JNA调用user32.dll函数CloseWindow和OpenIcon的代码;这些是Windows在您单击应用程序的任务栏图标时调用的功能-
(确切地说,我不确定这些不是实际功能,但是它们的作用相同)

import java.awt.Component;
import java.awt.Window;
import com.sun.jna.Library;
import com.sun.jna.Native;
import com.sun.jna.platform.win32.WinDef.HWND;

public class IconifyUtilityClass
{
    public static void minimize(Window window)
    {
        HWND hWnd = getHWND(window);
        User32dll.INSTANCE.CloseWindow(hWnd); //call CloseWindow with this windows handle
    }

    public static void restore(Window window)
    {
        HWND hWnd = getHWND(window);
        User32dll.INSTANCE.OpenIcon(hWnd); //call OpenIcon with this windows handle
    }

    private interface User32dll extends Library
    {
        User32dll INSTANCE = (User32dll) Native.loadLibrary("user32.dll", User32dll.class);
        boolean OpenIcon(HWND hWnd);
        boolean CloseWindow(HWND hWnd);
    }

    private static HWND getHWND(Component comp)
    {
        return new HWND(Native.getComponentPointer(comp));
    }
}

要调用代码,只需像这样传递您的框架或对话框

JFrame frame = new JFrame();
...
IconifyUtilityClass.minimize(frame); //minimize your frame
...
IconifyUtilityClass.restore(frame); //restore your frame

值得注意的是,在Windows 7中,未修饰的框架根本不动画(即使使用user32.dll
AnimateWindow函数)。因此,如果您的目标是使框架在任何地方进行动画处理,那么您是对的,那么您就必须自己做。JavaFx有一些非常不错的动画素材,可以帮助解决这一问题。



 类似资料:
  • 当我的项目启动时,主框架的下半部分位于任务栏下方。 如何解决这个问题。

  • 本文向大家介绍Vue入门之animate过渡动画效果,包括了Vue入门之animate过渡动画效果的使用技巧和注意事项,需要的朋友参考一下 简介: transition方法的使用 transition内置方法 transition-group  animate库实现过渡动画 总结 以上所述是小编给大家介绍的Vue入门之animate过渡动画效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小

  • CSS3 过渡是元素从一种样式逐渐改变为另一种的效果。 尽管 CSS3 过渡效果是足够的过渡的一个元素,但是 text-transform 属性可以提高 CSS3 过渡效果的风格。 主要有四个属性的CSS3转换效果,已被描述如下: transition-property transition-duration transition-timing-function transition-delay

  • 主要内容:使用案例过渡效果(Transition)插件提供了简单的过渡效果。 如果您想要单独引用该插件的功能,那么除了其他的 JS 文件,您还需要引用 transition.js。或者,正如 Bootstrap 插件概览 一章中所提到,您可以引用 bootstrap.js 或压缩版的 bootstrap.min.js。 Transition.js 是 transitionEnd 事件和 CSS 过渡效果模拟器的基本

  • 主要内容:1. transition-property,2. transition-duration,3. transition-timing-function,4. transition-delay,5. transition通常当 CSS 的属性值更改后,浏览器会立即更新相应的样式,例如当鼠标悬停在元素上时,通过 :hover 选择器定义的样式会立即应用在元素上。在 CSS3 中加入了一项过渡功能,通过该功能您可以将元素从一种样式在指定时间内平滑的过渡到另一种样式,类似于简单的动画,但无需借

  • 概述 Vue 在插入、更新或者移除 DOM 时,提供多种不同方式的应用过渡效果。 包括以下工具: 在 CSS 过渡和动画中自动应用 class 可以配合使用第三方 CSS 动画库,如 Animate.css 在过渡钩子函数中使用 JavaScript 直接操作 DOM 可以配合使用第三方 JavaScript 动画库,如 Velocity.js 在这里,我们只会讲到进入、离开和列表的过渡, 你也可