最近闲来无事, 学习学习swing。
在查看JPopMenu的代码时候突发奇想, 想实现一个环形的弹出菜单,说干就干。
我们都知道, swing 组件的位置和大小是由于layout 管理的,所以想实现环形的弹出菜单就必须实现一个环形的布局管理器。请看我的实现
效果
package info.mikewang.gui.layout;
import static java.lang.Math.PI;
import static java.lang.Math.round;
import static java.lang.Math.sin;
import static java.lang.Math.cos;
import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.LayoutManager;
import java.awt.Point;
import java.awt.Rectangle;
public class CircleLayout implements LayoutManager {
int maxCompWidth = 0; // 最大组件宽度
int maxCompHeight = 0; // 最大组件高度
int lc = 0; // 组件数(边的个数,即多边形边的个数)
double v = 1.5D; // 缩放因子
double cd = 0; // 组件和组件之间的距离(中心点到中心点)
int l; // 外截正方形边长/2
int lw = 0; // 调整过的边长
int lh = 0;
@Override
public void addLayoutComponent(String name, Component comp) {
}
@Override
public void layoutContainer(Container parent) {
synchronized (parent.getTreeLock()) {
Dimension d = parent.getPreferredSize();
Point cp = new Point(d.width / 2, d.height / 2);
double dx = 0, dy = 0;
int cpx = 0, cpy = 0;
for (int i = 0; i < lc; i++) {
// 下面两行的代码要是看不懂的话,就去翻翻初中2年纪的几何书吧
dx = sin(i * (2 * PI / lc)) * l;
dy = -cos(i * (2 * PI / lc)) * l;
cpx = (int) (cp.x + dx);
cpy = (int) (cp.y + dy);
Point cpp = new Point(cpx, cpy);
Component comp = parent.getComponent(i);
Dimension compSize = comp.getPreferredSize();
comp.setBounds(calcR(cpp, compSize));
}
}
}
@Override
public Dimension minimumLayoutSize(Container parent) {
lc = parent.getComponentCount();
Component[] components = parent.getComponents();
for (Component component : components) {
Dimension d = component.getPreferredSize();
if (d.width > this.maxCompWidth) {
this.maxCompWidth = d.width;
}
if (d.height > this.maxCompHeight) {
this.maxCompHeight = d.height;
}
}
calc();
return new Dimension(lw, lh);
}
@Override
public Dimension preferredLayoutSize(Container parent) {
return minimumLayoutSize(parent);
}
@Override
public void removeLayoutComponent(Component comp) {
}
private void calc() {
cd = maxCompWidth * v;
// 根据正多边形的一条边长,计算出这个多边形外切圆形的外切矩形的边长(近似值)
// 使用正弦定理,
double x = cd / sin(2 * PI / lc);
l = (int) round(x);
lh = 2 * l + maxCompHeight;
lw = 2 * l + maxCompWidth;
}
private Rectangle calcR(Point p, Dimension d) {
int y = p.y - d.height / 2;
int x = p.x - d.width / 2;
return new Rectangle(new Point(x, y), d);
}
}
环形 弹出菜单实现
package info.mikewang.gui.layout;
import javax.swing.JPopupMenu;
public class CirclePopupMenu extends JPopupMenu {
private static final long serialVersionUID = 7318307166817760768L;
public CirclePopupMenu() {
this.setLayout(new CircleLayout());
}
}
有个问题, 顺便在这里问一下:
如何才能把弹出窗口的背景设置成透明呀??
- 大小: 18.5 KB
分享到:
相关推荐
在这个“jquery点击分享环形弹出菜单.zip”压缩包中,包含了一个利用jQuery实现的特色功能——点击分享按钮时,弹出一个环形布局的菜单。这个功能在网页设计中常用于社交媒体分享,用户只需轻轻一点,就能轻松分享...
在"html5+jQuery实现的环形按钮菜单点击弹出弹性图标菜单特效源码.zip"这个项目中,我们将深入探讨如何利用这两种技术来构建一个独特的用户界面元素。 首先,HTML5作为现代Web标准的核心部分,提供了许多新的标签和...
jquery环形菜单制作点击弹出图标环形菜单代码 jquery环形菜单制作点击弹出图标环形菜单代码 jquery环形菜单制作点击弹出图标环形菜单代码 jquery环形菜单制作点击弹出图标环形菜单代码 jquery环形菜单制作点击弹出...
综上所述,实现“纯CSS3环形菜单动画 可展开二级子菜单”涉及到了CSS3的多个核心特性,包括变换(`transform`)、伪类选择器(`:hover`)、过渡(`transition`)、动画(`animation`)、布局(如`flexbox`或`grid`)...
本资源"jquery点击弹出图标环形菜单代码.zip"提供了一个利用jQuery实现的创新性菜单导航特效,尤其适用于增强网站的用户界面体验。 首先,环形菜单是一种独特且吸引人的设计模式,它将菜单项围绕一个中心点以圆形...
【jQuery五彩环形弹出菜单特效】是一个适用于网页设计的实用工具,它基于JavaScript库jQuery和CSS样式来实现一种独特且吸引人的交互式菜单效果。这个特效将菜单项以环形排列,当用户鼠标悬停在某个菜单项上时,会以...
在本文中,我们将深入探讨如何使用Qt框架来实现各种创新的菜单设计,包括环形菜单、悬浮球菜单和动画菜单。这些高级菜单设计为用户界面增添了互动性和视觉吸引力,是现代应用程序中提升用户体验的重要元素。 首先,...
环形菜单是一种创新的用户界面元素,尤其在移动设备上,它可以提供一种高效且美观的方式来...通过学习和理解该项目的源码,开发者不仅可以掌握环形菜单的实现原理,还能深入理解Android应用开发中的核心概念和技术。
5. **布局管理**:合理安排菜单项的位置,可能需要用到RelativeLayout或LinearLayout等布局容器。 6. **状态保存与恢复**:如果需要,还需考虑菜单的打开/关闭状态在配置更改(如屏幕旋转)时的保存和恢复。 在提供...
环形菜单是一种创新的用户界面元素,...总之,"一个别致的环形菜单.zip" 提供了一个学习和实践Android自定义视图和动画的好机会,同时也展示了开源文化的力量,让开发者能够从他人的工作成果中获益,并为社区做出贡献。
对于环形菜单,我们需要自定义布局管理器来使菜单项围绕中心点呈环状排列。 2. **几何形状** - 使用`Path`或`Shape`类来绘制环形和菜单项的形状。环形可能由`ArcSegment`或`PieSegment`来构建,而菜单项可以是圆形...
环形菜单是一种创新的用户界面元素,它将菜单项组织成一个圆形布局,通常用于触摸屏设备或图形用户界面中,以提供独特且直观的交互体验。这种设计可以使用户通过旋转手势来浏览和选择不同的功能或操作,尤其适用于...
在Android开发中,动态环形菜单是一种独特且吸引用户的交互设计。它通常用于展示一系列可选操作,如应用的功能选项或者设置项,用户通过点击或滑动触发菜单展开或收起,形成一个环绕中心的环状布局。这种设计在很多...
这个环形菜单利用了jQuery的强大功能和CSS3的现代特性,实现了一个可旋转弹出并能平滑收回的效果,同时伴有音效,使得用户操作更加生动有趣。 首先,jQuery是JavaScript的一个库,它简化了DOM操作、事件处理、动画...
在这个函数中,我们将编写弹出环形菜单的逻辑。 接下来,我们讨论环形菜单的布局。环形布局通常需要利用CSS3的transform属性,特别是rotate和translate。当用户点击图标后,我们可以动态修改子元素的transform值,...
在本文中,我们将深入探讨如何实现“CSS3环形菜单切换动画特效”,这是一种现代且具有科技感的网页设计技术。CSS3(层叠样式表第三版)为网页设计师提供了丰富的功能,包括过渡、动画和变换,使我们能够创建出动态且...
1. **圆角边框**:通过`border-radius`属性,我们可以创建出圆形的菜单项,这为环形布局奠定了基础。 2. **定位和布局**:使用`position`(如`relative`或`absolute`)和`transform`属性,可以精确控制菜单项的位置...
这个“ios-环形标签菜单(demo功能大全).zip”文件很可能包含了多种实现环形菜单的示例代码,帮助开发者了解并学习如何在自己的应用中实现类似的功能。 环形菜单的核心在于其布局方式,它将各个菜单项分布在圆形的...
- **学习曲线**:对于习惯传统菜单的用户来说,环形菜单可能需要一些时间去适应。 - **可读性**:如果菜单项过多,或者文字和图标不清晰,可能会降低用户的识别速度。 - **无障碍性**:对于视力障碍或动作受限的用户...
在本文中,我们将深入探讨如何使用CSS3实现一个旋转的环形菜单动画特效。CSS3是层叠样式表的最新版本,它引入了许多强大的新特性,包括2D和3D变换、过渡效果以及动画,使得网页设计更加动态和富有表现力。 首先,让...