Code
JPanel p1 = new JPanel();
p1.setOpaque(false);
JPanel p2 = new JPanel() {
@Override protected void paintComponent(Graphics g) {
// super.paintComponent(g);
g.setColor(new Color(100, 50, 50, 100));
g.fillRect(0, 0, getWidth(), getHeight());
}
};
JPanel p3 = new JPanel() {
@Override protected void paintComponent(Graphics g) {
Graphics2D g2 = (Graphics2D) g;
// g2.setPaint(new Color(100, 120, 100, 100));
g2.setPaint(texture);
g2.fillRect(0, 0, getWidth(), getHeight());
}
};
protected JInternalFrame createFrame(JPanel panel) {
MyInternalFrame frame = new MyInternalFrame();
if (panel != null) {
frame.setContentPane(panel);
// JButton button = new JButton("button");
// button.setOpaque(false);
panel.add(new JLabel("label"));
panel.add(new JButton("button"));
}
desktop.add(frame);
frame.setOpaque(false);
frame.setVisible(true);
// ...
References
is this brown square background the correct button background behaviour?
ReplyDeletehttps://picasaweb.google.com/lh/photo/jpjqW6OXUbZr-UNEWXoeNw?feat=directlink
Oops, bit ugly...
ReplyDeleteI think this will need to call JPanel#setOpaque(false):
JPanel p2 = new JPanel() {
@Override public void paintComponent(Graphics g) {
g.setColor(new Color(100,50,50,100));
g.fillRect(0,0,getWidth(), getHeight());
}
};
p2.setOpaque(false);
la Nippa,
ReplyDeleteExample.jnlp, src.zip update. Thank you for point out.
looks better!
ReplyDeleteGood job
perfect! thank you so much!
ReplyDeleteGlad to be of service :)
Delete