From 66b344fba69e67b4dd137b5e10204aa30b99abbb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=99=BD=E5=B2=B3?= <445798420@qq.com> Date: Tue, 11 Aug 2020 15:21:49 +0800 Subject: [PATCH] =?UTF-8?q?CHART-15033=20linux=E8=AE=BE=E8=AE=A1=E5=99=A8?= =?UTF-8?q?=E6=A0=87=E9=A2=98=E5=9B=BE=E4=BE=8B=E6=82=AC=E6=B5=AE=E4=BD=8D?= =?UTF-8?q?=E7=BD=AE=E8=AE=BE=E7=BD=AE=E6=A1=86=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../design/gui/frpane/UIBubbleFloatPane.java | 554 +++++++++--------- .../style/VanChartPlotLegendPane.java | 89 +-- .../designer/style/VanChartTitlePane.java | 75 +-- 3 files changed, 368 insertions(+), 350 deletions(-) diff --git a/designer-base/src/main/java/com/fr/design/gui/frpane/UIBubbleFloatPane.java b/designer-base/src/main/java/com/fr/design/gui/frpane/UIBubbleFloatPane.java index 0297353ee..03927ca46 100644 --- a/designer-base/src/main/java/com/fr/design/gui/frpane/UIBubbleFloatPane.java +++ b/designer-base/src/main/java/com/fr/design/gui/frpane/UIBubbleFloatPane.java @@ -9,14 +9,17 @@ import com.fr.stable.Constants; import javax.swing.JComponent; import javax.swing.JPanel; import javax.swing.SwingUtilities; +import javax.swing.border.Border; import java.awt.AWTEvent; import java.awt.BasicStroke; import java.awt.BorderLayout; import java.awt.Color; +import java.awt.Component; import java.awt.Dialog; import java.awt.Frame; import java.awt.Graphics; import java.awt.Graphics2D; +import java.awt.Insets; import java.awt.Point; import java.awt.Polygon; import java.awt.Rectangle; @@ -29,303 +32,312 @@ import java.awt.event.MouseEvent; /** * @author Jerry - * 非模态悬浮对话框,气泡形状 + * 非模态悬浮对话框,气泡形状 */ public abstract class UIBubbleFloatPane extends BasicBeanPane { - private static final long serialVersionUID = -6386018511442190959L; - private static int OFF_LEFT = 10; + private static final long serialVersionUID = -6386018511442190959L; + private static int OFF_LEFT = 10; private static final int ARROR_PARALLEL = 30; private static final int ARROR_VERTICAL = 20; private static final int TITLE_HEIGHT = 60; private static final double TIME_DEFAULT = 0.5; private static final double TIME_GAP = 0.1; - private BasicBeanPane contentPane; - private Rectangle bounds; - private int arrowPosition; - private double time = 0.5; - - private UIDialog showDialog; - - /** - * @param arrowPosition 箭头的位置,上下左右,暂时只处理了左边,后面用到了再说 TODO - * @param arrowPoint 箭头的坐标点 - * @param contentPane 对话框中的Panel - */ - public UIBubbleFloatPane(int arrowPosition, Point arrowPoint, BasicBeanPane contentPane) { - this(arrowPosition, arrowPoint, contentPane, contentPane.getPreferredSize().width, contentPane.getPreferredSize().height); - } - - /** - * 这个方法主要用于那些宽度和高度有变化的面板,因为显然外面的气泡要固定大小,不然忽大忽小,体验太差了 - * - * @param arrowPosition 箭头的位置,上下左右,暂时只处理了左边,后面用到了再说 TODO - * @param arrowPoint 箭头的坐标点 - * @param contentPane 对话框中的Panel - * @param width 对话框中的Panel的宽度,写死了 - * @param height 对话框中的Panel的高度,写死了 - */ - public UIBubbleFloatPane(int arrowPosition, Point arrowPoint, BasicBeanPane contentPane, int width, int height) { - this.contentPane = contentPane; - this.arrowPosition = arrowPosition; - this.time = initBoundsTime(arrowPosition, arrowPoint, width, height); - if (arrowPosition == Constants.LEFT) { - this.bounds = new Rectangle(arrowPoint.x - width, (int) (arrowPoint.y - height * time), width, height); - } else if (arrowPosition == Constants.TOP) { - this.bounds = new Rectangle((int) (arrowPoint.x - width * time), arrowPoint.y , width, height); - } else if (arrowPosition == Constants.RIGHT) { - this.bounds = new Rectangle(arrowPoint.x - OFF_LEFT * 2 - width, (int) (arrowPoint.y - height * time), width, height); - } - - initComponents(); - } + private BasicBeanPane contentPane; + private Rectangle bounds; + private int arrowPosition; + private double time = 0.5; + + private UIDialog showDialog; + + /** + * @param arrowPosition 箭头的位置,上下左右,暂时只处理了左边,后面用到了再说 TODO + * @param arrowPoint 箭头的坐标点 + * @param contentPane 对话框中的Panel + */ + public UIBubbleFloatPane(int arrowPosition, Point arrowPoint, BasicBeanPane contentPane) { + this(arrowPosition, arrowPoint, contentPane, contentPane.getPreferredSize().width, contentPane.getPreferredSize().height); + } + + /** + * 这个方法主要用于那些宽度和高度有变化的面板,因为显然外面的气泡要固定大小,不然忽大忽小,体验太差了 + * + * @param arrowPosition 箭头的位置,上下左右,暂时只处理了左边,后面用到了再说 TODO + * @param arrowPoint 箭头的坐标点 + * @param contentPane 对话框中的Panel + * @param width 对话框中的Panel的宽度,写死了 + * @param height 对话框中的Panel的高度,写死了 + */ + public UIBubbleFloatPane(int arrowPosition, Point arrowPoint, BasicBeanPane contentPane, int width, int height) { + this.contentPane = contentPane; + this.arrowPosition = arrowPosition; + this.time = initBoundsTime(arrowPosition, arrowPoint, width, height); + if (arrowPosition == Constants.LEFT) { + this.bounds = new Rectangle(arrowPoint.x - width, (int) (arrowPoint.y - height * time), width, height); + } else if (arrowPosition == Constants.TOP) { + this.bounds = new Rectangle((int) (arrowPoint.x - width * time), arrowPoint.y, width, height); + } else if (arrowPosition == Constants.RIGHT) { + this.bounds = new Rectangle(arrowPoint.x - OFF_LEFT * 2 - width, (int) (arrowPoint.y - height * time), width, height); + } + + initComponents(); + } /** * show对话框 + * * @param fatherPane 上一层界面 parentPane - * @param ob 传入的内容,在show之前populate + * @param ob 传入的内容,在show之前populate */ - public void show(JComponent fatherPane, T ob) { - populateBean(ob); - UIDialog dialog = showUnsizedWindow(SwingUtilities.getWindowAncestor(fatherPane)); - showDialog = dialog; - Toolkit.getDefaultToolkit().addAWTEventListener(awt, AWTEvent.MOUSE_EVENT_MASK); - dialog.setVisible(true); - } - - /** - * 数据展现 - */ - public void populateBean(T ob) { - contentPane.populateBean(ob); - } - - /** - * 停止编辑, 更新至最新的面板到属性保存 - */ - public T updateBean() { - updateContentPane(); - return contentPane.updateBean(); - } - - /** - * 需要实现更新内容,将updateBean传值给对象即可,在窗口消失的时候会被调用 - */ - protected abstract void updateContentPane(); - - /** - * 以对话框的形式弹出 - * - * @param window 窗口 - * @return 对话框 - */ - public UIDialog showUnsizedWindow(Window window) { - CustomShapedDialog dg = null; - if (window instanceof Frame) { - dg = new CustomShapedDialog((Frame) window); - } else { - dg = new CustomShapedDialog((Dialog) window); - } - if (arrowPosition == Constants.LEFT || arrowPosition == Constants.RIGHT) { - dg.setSize(bounds.width + ARROR_PARALLEL, bounds.height + ARROR_VERTICAL); - } else { - dg.setSize(bounds.width + ARROR_VERTICAL, bounds.height + ARROR_PARALLEL); - } - - dg.setLocation(bounds.x, bounds.y); - dg.setBackground(Color.blue); - dg.setResizable(false); - return dg; - } - - @Override - protected String title4PopupWindow() { - return null; - } - - private double initBoundsTime(int arrowPosition, Point arrowPoint, int width, int height) { - int x = arrowPoint.x; - int y = arrowPoint.y; - int screenWidth = Toolkit.getDefaultToolkit().getScreenSize().width; - int screenHeight = Toolkit.getDefaultToolkit().getScreenSize().height - TITLE_HEIGHT; - double time = TIME_DEFAULT; - - if (arrowPosition == Constants.LEFT || arrowPosition == Constants.RIGHT) { - while (y + time * height > screenHeight && time > 0) { - time -= TIME_GAP; - } - - while (y - (1 - time) * height < 0 && time < 1) { - time += TIME_GAP; - } - } else if (arrowPosition == Constants.TOP) { - while (x + time * width > screenWidth && time > 0) { - time -= TIME_GAP; - } - - while (x - (1 - time) * width < 0 && time < 1) { - time += TIME_GAP; - } - } - return 1 - time; - } - - private AWTEventListener awt = new AWTEventListener() { - public void eventDispatched(AWTEvent event) { - doSomeInAll(event); - } - }; - - private void doSomeInAll(AWTEvent event) { - if (event instanceof MouseEvent) { - MouseEvent mv = (MouseEvent) event; - if (mv.getClickCount() > 0) { - Point point = new Point((int) (mv.getLocationOnScreen().getX()) - 2 * OFF_LEFT, (int) mv.getLocationOnScreen().getY()); - // 判断鼠标点击是否在边界内 - if (!containsPoint(point) && showDialog != null) { - updateContentPane(); - showDialog.setVisible(false); - Toolkit.getDefaultToolkit().removeAWTEventListener(awt); - } - } - } - } + public void show(JComponent fatherPane, T ob) { + populateBean(ob); + if (showDialog == null) { + showDialog = showUnsizedWindow(SwingUtilities.getWindowAncestor(fatherPane)); + } + Toolkit.getDefaultToolkit().addAWTEventListener(awt, AWTEvent.MOUSE_EVENT_MASK); + showDialog.setVisible(true); + } + + /** + * 数据展现 + */ + public void populateBean(T ob) { + contentPane.populateBean(ob); + } + + /** + * 停止编辑, 更新至最新的面板到属性保存 + */ + public T updateBean() { + updateContentPane(); + return contentPane.updateBean(); + } + + /** + * 需要实现更新内容,将updateBean传值给对象即可,在窗口消失的时候会被调用 + */ + protected abstract void updateContentPane(); + + /** + * 以对话框的形式弹出 + * + * @param window 窗口 + * @return 对话框 + */ + public UIDialog showUnsizedWindow(Window window) { + CustomShapedDialog dg = null; + if (window instanceof Frame) { + dg = new CustomShapedDialog((Frame) window); + } else { + dg = new CustomShapedDialog((Dialog) window); + } + if (arrowPosition == Constants.LEFT || arrowPosition == Constants.RIGHT) { + dg.setSize(bounds.width + ARROR_PARALLEL, bounds.height + ARROR_VERTICAL); + } else { + dg.setSize(bounds.width + ARROR_VERTICAL, bounds.height + ARROR_PARALLEL); + } + + dg.setLocation(bounds.x, bounds.y); + dg.setBackground(Color.blue); + dg.setResizable(false); + return dg; + } + + @Override + protected String title4PopupWindow() { + return null; + } + + private double initBoundsTime(int arrowPosition, Point arrowPoint, int width, int height) { + int x = arrowPoint.x; + int y = arrowPoint.y; + int screenWidth = Toolkit.getDefaultToolkit().getScreenSize().width; + int screenHeight = Toolkit.getDefaultToolkit().getScreenSize().height - TITLE_HEIGHT; + double time = TIME_DEFAULT; + + if (arrowPosition == Constants.LEFT || arrowPosition == Constants.RIGHT) { + while (y + time * height > screenHeight && time > 0) { + time -= TIME_GAP; + } + + while (y - (1 - time) * height < 0 && time < 1) { + time += TIME_GAP; + } + } else if (arrowPosition == Constants.TOP) { + while (x + time * width > screenWidth && time > 0) { + time -= TIME_GAP; + } + + while (x - (1 - time) * width < 0 && time < 1) { + time += TIME_GAP; + } + } + return 1 - time; + } + + private AWTEventListener awt = new AWTEventListener() { + public void eventDispatched(AWTEvent event) { + doSomeInAll(event); + } + }; + + private void doSomeInAll(AWTEvent event) { + if (event instanceof MouseEvent) { + MouseEvent mv = (MouseEvent) event; + if (mv.getClickCount() > 0) { + Point point = new Point((int) (mv.getLocationOnScreen().getX()) - 2 * OFF_LEFT, (int) mv.getLocationOnScreen().getY()); + // 判断鼠标点击是否在边界内 + if (!containsPoint(point) && showDialog != null) { + updateContentPane(); + showDialog.setVisible(false); + Toolkit.getDefaultToolkit().removeAWTEventListener(awt); + } + } + } + } private boolean containsPoint(Point point) { - if(arrowPosition == Constants.TOP){ + if (arrowPosition == Constants.TOP) { //箭头和按钮也算在pane内 Rectangle judgedBounds = new Rectangle(bounds.x, bounds.y - OFF_LEFT * 2, bounds.width, bounds.height + OFF_LEFT * 2 + OFF_LEFT); - return judgedBounds.contains(point); + return judgedBounds.contains(point); } return bounds.contains(point); } - private void initComponents() { - if(arrowPosition == Constants.LEFT || arrowPosition == Constants.RIGHT) { - this.setBounds(20, 10, bounds.width, bounds.height); - } else { - this.setBounds(10, 10, bounds.width, bounds.height); - } - - this.setLayout(new BorderLayout()); - this.add(contentPane, BorderLayout.CENTER); - } + private void initComponents() { + if (arrowPosition == Constants.LEFT || arrowPosition == Constants.RIGHT) { + this.setBounds(20, 10, bounds.width, bounds.height); + } else { + this.setBounds(10, 10, bounds.width, bounds.height); + } + + this.setLayout(new BorderLayout()); + this.add(contentPane, BorderLayout.CENTER); + } - private class CustomShapedDialog extends UIDialog { + private class CustomShapedDialog extends UIDialog { private static final int GAP_SMALL = 10; private static final int GAP = 20; private static final int GAP_BIG = 30; - public CustomShapedDialog(Frame parent) { - super(parent); - this.initComponents(); - } - - public CustomShapedDialog(Dialog parent) { - super(parent); - this.initComponents(); - } - - - private Shape getCustomShap() { - Polygon polygon = new Polygon(); - if (arrowPosition == Constants.LEFT) { - polygon.addPoint(GAP_SMALL, 0); - polygon.addPoint(bounds.width + GAP_BIG, 0); - polygon.addPoint(bounds.width + GAP_BIG, bounds.height + GAP); - polygon.addPoint(GAP_SMALL, bounds.height + GAP); - polygon.addPoint(GAP_SMALL, (int) ((bounds.height + GAP) * time) - GAP_SMALL); - polygon.addPoint(0, (int) ((bounds.height + GAP) * time - GAP)); - polygon.addPoint(GAP_SMALL, (int) ((bounds.height + GAP) * time - GAP_BIG)); - polygon.addPoint(GAP_SMALL, 0); - } else if (arrowPosition == Constants.TOP) { - polygon.addPoint(0, GAP_SMALL); - polygon.addPoint((int) (bounds.width * time + GAP_SMALL), GAP_SMALL); - polygon.addPoint((int) (bounds.width * time + GAP), 0); - polygon.addPoint((int) (bounds.getWidth() * time + GAP_BIG), GAP_SMALL); - polygon.addPoint(bounds.width + GAP, GAP_SMALL); - polygon.addPoint(bounds.width + GAP, bounds.height + GAP_BIG); - polygon.addPoint(0, bounds.height + GAP_BIG); - polygon.addPoint(0, GAP_SMALL); - } else if (arrowPosition == Constants.RIGHT) { - polygon.addPoint(0, 0); - polygon.addPoint(bounds.width + GAP, 0); - polygon.addPoint(bounds.width + GAP, (int) ((bounds.height + GAP) * time) - GAP_BIG); - polygon.addPoint(bounds.width + GAP_BIG, (int) ((bounds.height + GAP) * time) - GAP); - polygon.addPoint(bounds.width + GAP, (int) ((bounds.height + GAP) * time) - GAP_SMALL); - polygon.addPoint(bounds.width + GAP, bounds.height + GAP); - polygon.addPoint(0, bounds.height + GAP); - polygon.addPoint(0, 0); - } - - return polygon; - } - - private Shape getShape4Board() { - Polygon polygon = new Polygon(); - if (arrowPosition == Constants.LEFT) { - polygon.addPoint(GAP_SMALL, 1); - polygon.addPoint(bounds.width + GAP_BIG - 1, 1); - polygon.addPoint(bounds.width + GAP_BIG - 1, bounds.height + GAP - 1); - polygon.addPoint(GAP_SMALL + 1, bounds.height + GAP - 1); - polygon.addPoint(GAP_SMALL + 1, (int) ((bounds.height + GAP) * time) - GAP_SMALL); - polygon.addPoint(1, (int) ((bounds.height + GAP) * time - GAP)); - polygon.addPoint(GAP_SMALL + 1, (int) ((bounds.height + GAP) * time - GAP_BIG)); - polygon.addPoint(GAP_SMALL + 1, 1); - } else if (arrowPosition == Constants.TOP) { - polygon.addPoint(1, GAP_SMALL + 1); - polygon.addPoint((int) (bounds.width * time + GAP_SMALL), GAP_SMALL + 1); - polygon.addPoint((int) (bounds.width * time + GAP), 1); - polygon.addPoint((int) (bounds.getWidth() * time + GAP_BIG), GAP_SMALL + 1); - polygon.addPoint(bounds.width + GAP - 1, GAP_SMALL + 1); - polygon.addPoint(bounds.width + GAP - 1, bounds.height + GAP_BIG - 1); - polygon.addPoint(1, bounds.height + GAP_BIG - 1); - polygon.addPoint(1, GAP_SMALL + 1); - } else if(arrowPosition == Constants.RIGHT) { - polygon.addPoint(1, 1); - polygon.addPoint(bounds.width + GAP - 1, 1); - polygon.addPoint(bounds.width + GAP - 1, (int) ((bounds.height + GAP) * time) - GAP_BIG); - polygon.addPoint(bounds.width + GAP_BIG - 1, (int) ((bounds.height + GAP) * time) - GAP); - polygon.addPoint(bounds.width + GAP - 1, (int) ((bounds.height + GAP) * time) - GAP_SMALL); - polygon.addPoint(bounds.width + GAP - 1, bounds.height + GAP - 1); - polygon.addPoint(1, bounds.height + GAP - 1); - polygon.addPoint(1, 0); - } - return polygon; - } - - /** - * 画出界面的样式, 边框等. - */ - public void paint(Graphics g) { - super.paint(g); - Graphics2D g2d = (Graphics2D) g; - Stroke oldStroke = g2d.getStroke(); - g2d.setStroke(new BasicStroke(2, BasicStroke.CAP_SQUARE, BasicStroke.JOIN_ROUND)); - g2d.setColor(new Color(51, 51, 51)); - g2d.drawPolygon((Polygon) getShape4Board()); - g2d.setStroke(oldStroke); - } - - protected void initComponents() { - setUndecorated(true); - try { - AWTUtilities.setWindowShape(CustomShapedDialog.this, this.getCustomShap()); - } catch (UnsupportedOperationException e) { + public CustomShapedDialog(Frame parent) { + super(parent); + this.initComponents(); + } + + public CustomShapedDialog(Dialog parent) { + super(parent); + this.initComponents(); + } + + + private Shape getCustomShap() { + Polygon polygon = new Polygon(); + if (arrowPosition == Constants.LEFT) { + polygon.addPoint(GAP_SMALL, 0); + polygon.addPoint(bounds.width + GAP_BIG, 0); + polygon.addPoint(bounds.width + GAP_BIG, bounds.height + GAP); + polygon.addPoint(GAP_SMALL, bounds.height + GAP); + polygon.addPoint(GAP_SMALL, (int) ((bounds.height + GAP) * time) - GAP_SMALL); + polygon.addPoint(0, (int) ((bounds.height + GAP) * time - GAP)); + polygon.addPoint(GAP_SMALL, (int) ((bounds.height + GAP) * time - GAP_BIG)); + polygon.addPoint(GAP_SMALL, 0); + } else if (arrowPosition == Constants.TOP) { + polygon.addPoint(0, GAP_SMALL - 2); + polygon.addPoint((int) (bounds.width * time + GAP_SMALL), GAP_SMALL - 2); + polygon.addPoint((int) (bounds.width * time + GAP), 0); + polygon.addPoint((int) (bounds.getWidth() * time + GAP_BIG), GAP_SMALL - 2); + polygon.addPoint(bounds.width + GAP, GAP_SMALL - 2); + polygon.addPoint(bounds.width + GAP, bounds.height + GAP_BIG); + polygon.addPoint(0, bounds.height + GAP_BIG); + polygon.addPoint(0, GAP_SMALL - 2); + } else if (arrowPosition == Constants.RIGHT) { + polygon.addPoint(0, 0); + polygon.addPoint(bounds.width + GAP, 0); + polygon.addPoint(bounds.width + GAP, (int) ((bounds.height + GAP) * time) - GAP_BIG); + polygon.addPoint(bounds.width + GAP_BIG, (int) ((bounds.height + GAP) * time) - GAP); + polygon.addPoint(bounds.width + GAP, (int) ((bounds.height + GAP) * time) - GAP_SMALL); + polygon.addPoint(bounds.width + GAP, bounds.height + GAP); + polygon.addPoint(0, bounds.height + GAP); + polygon.addPoint(0, 0); + } + + return polygon; + } + + private Shape getShape4Board() { + Polygon polygon = new Polygon(); + if (arrowPosition == Constants.LEFT) { + polygon.addPoint(GAP_SMALL, 1); + polygon.addPoint(bounds.width + GAP_BIG - 1, 1); + polygon.addPoint(bounds.width + GAP_BIG - 1, bounds.height + GAP - 1); + polygon.addPoint(GAP_SMALL + 1, bounds.height + GAP - 1); + polygon.addPoint(GAP_SMALL + 1, (int) ((bounds.height + GAP) * time) - GAP_SMALL); + polygon.addPoint(1, (int) ((bounds.height + GAP) * time - GAP)); + polygon.addPoint(GAP_SMALL + 1, (int) ((bounds.height + GAP) * time - GAP_BIG)); + polygon.addPoint(GAP_SMALL + 1, 1); + } else if (arrowPosition == Constants.TOP) { + polygon.addPoint(1, GAP_SMALL - 1); + polygon.addPoint((int) (bounds.width * time + GAP_SMALL), GAP_SMALL - 1); + polygon.addPoint((int) (bounds.width * time + GAP), 1); + polygon.addPoint((int) (bounds.getWidth() * time + GAP_BIG), GAP_SMALL - 1); + polygon.addPoint(bounds.width + GAP - 1, GAP_SMALL - 1); + polygon.addPoint(bounds.width + GAP - 1, bounds.height + GAP_BIG - 1); + polygon.addPoint(1, bounds.height + GAP_BIG - 1); + polygon.addPoint(1, GAP_SMALL - 1); + } else if (arrowPosition == Constants.RIGHT) { + polygon.addPoint(1, 1); + polygon.addPoint(bounds.width + GAP - 1, 1); + polygon.addPoint(bounds.width + GAP - 1, (int) ((bounds.height + GAP) * time) - GAP_BIG); + polygon.addPoint(bounds.width + GAP_BIG - 1, (int) ((bounds.height + GAP) * time) - GAP); + polygon.addPoint(bounds.width + GAP - 1, (int) ((bounds.height + GAP) * time) - GAP_SMALL); + polygon.addPoint(bounds.width + GAP - 1, bounds.height + GAP - 1); + polygon.addPoint(1, bounds.height + GAP - 1); + polygon.addPoint(1, 0); + } + return polygon; + } + + protected void initComponents() { + setUndecorated(true); + try { + AWTUtilities.setWindowShape(CustomShapedDialog.this, this.getCustomShap()); + } catch (UnsupportedOperationException e) { FineLoggerFactory.getLogger().info("Not support"); - } - final JPanel contentPane = (JPanel) this.getContentPane(); - this.setLayout(null); - contentPane.add(UIBubbleFloatPane.this); - setVisible(true); - } - - /** - * 检查 - */ - public void checkValid() throws Exception { - - } - } + } + final JPanel contentPane = (JPanel) this.getContentPane(); + this.setLayout(null); + contentPane.add(UIBubbleFloatPane.this); + contentPane.setBorder(new Border() { + @Override + public void paintBorder(Component c, Graphics g, int x, int y, int width, int height) { + Graphics2D g2d = (Graphics2D) g; + Stroke oldStroke = g2d.getStroke(); + g2d.setStroke(new BasicStroke(2, BasicStroke.CAP_SQUARE, BasicStroke.JOIN_ROUND)); + g2d.setColor(new Color(51, 51, 51)); + g2d.drawPolygon((Polygon) getShape4Board()); + g2d.setStroke(oldStroke); + } + + @Override + public Insets getBorderInsets(Component c) { + return null; + } + + @Override + public boolean isBorderOpaque() { + return false; + } + }); + } + + /** + * 检查 + */ + public void checkValid() throws Exception { + + } + } } \ No newline at end of file diff --git a/designer-chart/src/main/java/com/fr/van/chart/designer/style/VanChartPlotLegendPane.java b/designer-chart/src/main/java/com/fr/van/chart/designer/style/VanChartPlotLegendPane.java index 3c5e992b9..241a93ea0 100644 --- a/designer-chart/src/main/java/com/fr/van/chart/designer/style/VanChartPlotLegendPane.java +++ b/designer-chart/src/main/java/com/fr/van/chart/designer/style/VanChartPlotLegendPane.java @@ -1,7 +1,6 @@ package com.fr.van.chart.designer.style; import com.fr.base.BaseUtils; -import com.fr.base.Style; import com.fr.chart.chartattr.Plot; import com.fr.design.dialog.BasicPane; import com.fr.design.gui.frpane.UIBubbleFloatPane; @@ -61,6 +60,7 @@ public class VanChartPlotLegendPane extends BasicPane { private UIButtonGroup layoutButton; private JPanel layoutPane; private VanChartFloatPositionPane customFloatPositionPane; + private UIBubbleFloatPane uiBubbleFloatPane; //区域显示策略 恢复用注释。下面4行删除。 private UIButtonGroup customSize; @@ -80,7 +80,7 @@ public class VanChartPlotLegendPane extends BasicPane { initComponents(); } - public VanChartPlotLegendPane(VanChartStylePane parent){ + public VanChartPlotLegendPane(VanChartStylePane parent) { this.parent = parent; initComponents(); } @@ -118,9 +118,9 @@ public class VanChartPlotLegendPane extends BasicPane { new Component[]{legendPane}, }; - JPanel panel = TableLayoutHelper.createTableLayoutPane(components,row,col); + JPanel panel = TableLayoutHelper.createTableLayoutPane(components, row, col); this.setLayout(new BorderLayout()); - this.add(panel,BorderLayout.CENTER); + this.add(panel, BorderLayout.CENTER); addLegendListener(); } @@ -133,7 +133,7 @@ public class VanChartPlotLegendPane extends BasicPane { }); } - protected JPanel createLegendPaneWithoutHighlight(){ + protected JPanel createLegendPaneWithoutHighlight() { borderPane = new VanChartBorderWithRadiusPane(); backgroundPane = new VanChartBackgroundWithOutImagePane(); @@ -141,19 +141,19 @@ public class VanChartPlotLegendPane extends BasicPane { double f = TableLayout.FILL; double e = TableLayout4VanChartHelper.EDIT_AREA_WIDTH; double[] columnSize = {f, e}; - double[] rowSize = { p,p,p,p,p,p,p}; + double[] rowSize = {p, p, p, p, p, p, p}; Component[][] components = new Component[][]{ - new Component[]{createTitlePositionPane(new double[]{p,p,p},columnSize),null}, - new Component[]{createTitleStylePane(),null} , - new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Border"),borderPane),null}, - new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Background"), backgroundPane),null}, - new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Display_Strategy"), createDisplayStrategy()),null} + new Component[]{createTitlePositionPane(new double[]{p, p, p}, columnSize), null}, + new Component[]{createTitleStylePane(), null}, + new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Border"), borderPane), null}, + new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Background"), backgroundPane), null}, + new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Display_Strategy"), createDisplayStrategy()), null} }; return TableLayoutHelper.createTableLayoutPane(components, rowSize, columnSize); } - protected JPanel createLegendPane(){ + protected JPanel createLegendPane() { borderPane = new VanChartBorderWithRadiusPane(); backgroundPane = new VanChartBackgroundWithOutImagePane(); highlightPane = createHighlightPane(); @@ -166,14 +166,14 @@ public class VanChartPlotLegendPane extends BasicPane { double f = TableLayout.FILL; double e = TableLayout4VanChartHelper.EDIT_AREA_WIDTH; double[] columnSize = {f, e}; - double[] rowSize = { p,p,p,p,p,p,p,p}; + double[] rowSize = {p, p, p, p, p, p, p, p}; Component[][] components = new Component[][]{ - new Component[]{createTitlePositionPane(new double[]{p,p,p},columnSize),null}, - new Component[]{createTitleStylePane(),null} , - new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Border"),borderPane),null}, - new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Background"), backgroundPane),null}, - new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Display_Strategy"), panel),null}, + new Component[]{createTitlePositionPane(new double[]{p, p, p}, columnSize), null}, + new Component[]{createTitleStylePane(), null}, + new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Border"), borderPane), null}, + new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Background"), backgroundPane), null}, + new Component[]{TableLayout4VanChartHelper.createExpandablePaneWithTitle(Toolkit.i18nText("Fine-Design_Chart_Display_Strategy"), panel), null}, }; return TableLayoutHelper.createTableLayoutPane(components, rowSize, columnSize); } @@ -205,12 +205,12 @@ public class VanChartPlotLegendPane extends BasicPane { customFloatPositionButton.setEventBannded(true); Component[][] components = new Component[][]{ - new Component[]{null,null}, - new Component[]{new UILabel(Toolkit.i18nText("Fine-Design_Chart_Layout_Position")),location}, - new Component[]{null,customFloatPositionButton} + new Component[]{null, null}, + new Component[]{new UILabel(Toolkit.i18nText("Fine-Design_Chart_Layout_Position")), location}, + new Component[]{null, customFloatPositionButton} }; - customFloatPositionPane = new VanChartFloatPositionPane(); + customFloatPositionPane = new VanChartFloatPositionPane(); layoutPane = createLayoutPane(); initPositionListener(); @@ -241,7 +241,7 @@ public class VanChartPlotLegendPane extends BasicPane { return TableLayout4VanChartHelper.createGapTableLayoutPane(components, new double[]{p, p}, new double[]{f, e}); } - private void initPositionListener(){ + private void initPositionListener() { location.addChangeListener(new ChangeListener() { @Override @@ -262,18 +262,20 @@ public class VanChartPlotLegendPane extends BasicPane { checkLayoutPaneVisible(); checkDisplayStrategyUse(); - if(customFloatPositionPane == null) { - customFloatPositionPane = new VanChartFloatPositionPane(); + if (customFloatPositionPane == null) { + customFloatPositionPane = new VanChartFloatPositionPane(); + } + if (uiBubbleFloatPane == null) { + Point comPoint = customFloatPositionButton.getLocationOnScreen(); + Point arrowPoint = new Point(comPoint.x + customFloatPositionButton.getWidth() / 2 - GAP, comPoint.y + customFloatPositionButton.getHeight()); + uiBubbleFloatPane = new UIBubbleFloatPane(Constants.TOP, arrowPoint, customFloatPositionPane, WIDTH, HEIGHT) { + @Override + public void updateContentPane() { + parent.attributeChanged(); + } + }; } - Point comPoint = customFloatPositionButton.getLocationOnScreen(); - Point arrowPoint = new Point(comPoint.x + customFloatPositionButton.getWidth()/2 - GAP, comPoint.y + customFloatPositionButton.getHeight()); - UIBubbleFloatPane