2017-04-21 107 views
0

当我在面板中添加面板和对象时,我希望将图像设置为背景并通过置于其上的面板显示。我读过你可以做这个赌注设置panel.setOpaque(false)选项,但是这似乎并不奏效。通过顶部的面板使背景图像显示

这里是我的编译器目录和它是如何设置(使用的是IntelliJ)...

enter image description here

这里是背景图片...

enter image description here

下面是代码...

BackgroundPanel class>http://www.camick.com/java/source/BackgroundPanel.java

/** 
* Created by James Page on 4/16/2017. 
*/ 
package Main; 

import org.apache.commons.lang3.ArrayUtils; 

import java.awt.*; 
import java.awt.event.ActionEvent; 
import java.awt.event.ActionListener; 

import javax.imageio.ImageIO; 
import javax.swing.*; 
import javax.swing.border.Border; 
import javax.swing.border.TitledBorder; 

public class TestGui extends JFrame { 
    private final String[] guiCharSelDefault = {"--- Select Character ---"}; 
    private final String[] characters = {"charOne", "charTwo", "charThree", "charFour"}; 
    private final String[] GuiCharSel = (String[]) ArrayUtils.addAll(guiCharSelDefault, characters); 
    private final String[] weapon = {"Weapon"}; 
    private final String[][] allWeapons = { 
      { 
        "weakWeaponOne", "strongWeaponOne", "shortWeaponOne", "longWeaponOne" 
      }, 
      { 
        "weakWeaponTwo", "strongWeaponTwo", "shortWeaponTwo", "longWeaponTwo" 
      }, 
      { 
        "weakWeaponThree", "strongWeaponThree", "shortWeaponThree", "longWeaponThree" 
      }, 
      { 
        "weakWeaponFour", "strongWeaponFour", "shortWeaponFour", "longWeaponFour" 
      } 
    }; 
    private JComboBox charCombo = new JComboBox(GuiCharSel); 
    private JComboBox weaponsCombo = new JComboBox(weapon); 
    private BackgroundPanel backgroundFrame = createBackgroundFrame("../images/Background.png"); 
    private JPanel topFrame = createTopFrame(); 
    private JPanel centerFrame = createCenterFrame(); 

    //************************************************************************************** 

    private static GridBagConstraints setGbc(int gridx, int gridy, int gridWidth, int gridHeight, int ipadx, int ipady, String anchorLocation, double weightx, double weighty, Insets insets){ 
     GridBagConstraints gbc = new GridBagConstraints(); 

     if (anchorLocation.toUpperCase().equals("NORTHWEST")){ 
      gbc.anchor = GridBagConstraints.NORTHWEST; 
     } else if (anchorLocation.toUpperCase().equals("NORTH")){ 
      gbc.anchor = GridBagConstraints.NORTH; 
     } else if (anchorLocation.toUpperCase().equals("NORTHEAST")){ 
      gbc.anchor = GridBagConstraints.NORTHEAST; 
     } else if (anchorLocation.toUpperCase().equals("WEST")){ 
      gbc.anchor = GridBagConstraints.WEST; 
     } else if (anchorLocation.toUpperCase().equals("EAST")){ 
      gbc.anchor = GridBagConstraints.EAST; 
     } else if (anchorLocation.toUpperCase().equals("SOUTHWEST")){ 
      gbc.anchor = GridBagConstraints.SOUTHWEST; 
     } else if (anchorLocation.toUpperCase().equals("SOUTH")){ 
      gbc.anchor = GridBagConstraints.SOUTH; 
     } else if (anchorLocation.toUpperCase().equals("SOUTHEAST")){ 
      gbc.anchor = GridBagConstraints.SOUTHEAST; 
     } else { 
      gbc.anchor = GridBagConstraints.CENTER; 
     } 

     gbc.gridx = gridx; // column 
     gbc.gridy = gridy; // row 
     gbc.gridwidth = gridWidth; // number of columns 
     gbc.gridheight = gridHeight; // number of rows 
     gbc.ipadx = ipadx; // width of object 
     gbc.ipady = ipady; // height of object 
     gbc.weightx = weightx; // shifts rows to side of set anchor 
     gbc.weighty = weighty; // shifts columns to side of set anchor 
     gbc.insets = insets; // placement inside cell 
     gbc.fill = GridBagConstraints.HORIZONTAL; 
     gbc.fill = GridBagConstraints.VERTICAL; 

     return gbc; 
    } 

    private Insets setInsets(int top, int left, int bottom, int right){ 
     Insets insets = new Insets(top,left,bottom,right); 
     return insets; 
    } 

    //************************************************************************************** 

    private BackgroundPanel createBackgroundFrame(String imgLocName){ 
     Image backgroundImg = null; 
     try { 
      backgroundImg = ImageIO.read(getClass().getResource(imgLocName)); 
      System.out.println("File: " + imgLocName.toString()); 
     } catch (Exception e) { 
      System.out.println("Cannot read file: " + e); 
     } 
     BackgroundPanel bgPanel = new BackgroundPanel(backgroundImg, BackgroundPanel.SCALED, 0.0f, 0.0f); 
     return bgPanel; 
    } 

    private JPanel createTopFrame(){ 
     JPanel pnl = new JPanel(); 
     Border raisedBevel = BorderFactory.createRaisedBevelBorder(); 
     Color lineColor = new Color(224,224,224); 
     Border lineBorder = BorderFactory.createMatteBorder(5, 5, 5, 5, lineColor); 
     Border loweredBevel = BorderFactory.createLoweredBevelBorder(); 
     Border compoundSetup = BorderFactory.createCompoundBorder(raisedBevel, lineBorder); 
     Border compoundFinal = BorderFactory.createCompoundBorder(compoundSetup, loweredBevel); 
     TitledBorder topFrameTitle = BorderFactory.createTitledBorder(compoundFinal, "Character"); 
     topFrameTitle.setTitleJustification(TitledBorder.CENTER); 

     JLabel lineSplitter = new JLabel(); 
     Border lineSplitterBoarder = BorderFactory.createMatteBorder(0, 0, 0, 5, new Color(224,224,224)); 
     lineSplitter.setBorder(lineSplitterBoarder); 

     pnl.setBorder(topFrameTitle); 
     pnl.setLayout(new GridBagLayout()); 
     pnl.setPreferredSize(new Dimension(200, 60)); 

     charCombo.addActionListener(
       new ActionListener() { 
        public void actionPerformed(ActionEvent e) { 
         String charName = ((JComboBox)(e.getSource())).getSelectedItem().toString(); 
         if (charName.equals("charOne")){ 
          weaponsCombo.removeAllItems(); 
          weaponsCombo.setModel(new DefaultComboBoxModel(allWeapons[1])); 
         } 
        } 
       } 
     ); 
     pnl.add(charCombo, setGbc(0,0, 1,1, 0,0, "WEST", 0, 0, setInsets(0, 0, 0, 0))); 
     pnl.add(lineSplitter, setGbc(1,0, 1,1, 0,0, "WEST", 0, 0, setInsets(0, 10, 0, 0))); 
     pnl.add(weaponsCombo, setGbc(2,0, 1,1, 0,0, "WEST", 1, 1, setInsets(0, 10, 0, 0))); 

     pnl.setOpaque(false); 
     return pnl; 
    } 

    private JPanel createCenterFrame() { 
     JPanel pnl = new JPanel(); 
     Border raisedBevel = BorderFactory.createRaisedBevelBorder(); 
     Color lineColor = new Color(224, 224, 224); 
     Border lineBorder = BorderFactory.createMatteBorder(5, 5, 5, 5, lineColor); 
     Border loweredBevel = BorderFactory.createLoweredBevelBorder(); 
     Border compoundSetup = BorderFactory.createCompoundBorder(raisedBevel, lineBorder); 
     Border compoundFinal = BorderFactory.createCompoundBorder(compoundSetup, loweredBevel); 
     TitledBorder topFrameTitle = BorderFactory.createTitledBorder(compoundFinal, "Stuff"); 
     topFrameTitle.setTitleJustification(TitledBorder.CENTER); 

     pnl.setBorder(topFrameTitle); 
     pnl.setLayout(new GridBagLayout()); 

     pnl.setOpaque(false); 
     return pnl; 
    } 

    TestGui(){ 
     add(backgroundFrame); 
     add(topFrame, BorderLayout.NORTH); 
     add(centerFrame, BorderLayout.CENTER); 

     setSize(800,600); 
     setVisible(true); 
     setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
    } 

    //************************************************************************************** 

    public static void main(String[] args) { 
     new TestGui(); 
    } 
} 

我知道图像的背景被添加到GUI,因为如果我注释掉线构造//add(topFrame, BorderLayout.NORTH);//add(centerFrame, BorderLayout.CENTER);,图像显示在GUI上。任何人都知道如何通过这两个面板来显示背景图片?

+0

开始'setOpaque您面板(假)',即'pnl.setOpaque(假)'。你会发现很多组件默认是不透明的(除了'JLabel',因为它必须不同) – MadProgrammer

+0

这就是我在139和153行中尝试过的'pnl.setOpaque(false);'。它似乎没有工作... –

回答

2

你更换backgroundFramecenterFrame

add(backgroundFrame); 
add(topFrame, BorderLayout.NORTH); 
add(centerFrame, BorderLayout.CENTER); 

这是BorderLayout,它只能在每次它支持单个组件功能的5个可用的位置

相反,你要什么do是将其他面板添加到backgroundFrame或将backgroundFrame设置为框架的contentPane,例如

setContentPane(backgroundFrame); 
add(topFrame, BorderLayout.NORTH); 
add(centerFrame, BorderLayout.CENTER); 

Background

此外,作为一般的建议,避免使用setPreferredSize,有太多的东西,可以使出错

很抱歉打扰你,它看起来像它没有显示通过JScrollPane。我应该把这个问题作为一个新问题来解决吗?

JScrollPane是一个比较复杂的组成部分,它是由被用来提供滚动

JScrollPane

你需要做JScrollPane的功能性两个部分组成,它的JViewport透明的(以及你包装的视图)

所以,这是你的createCenterFrame方法的修改版本,它会创建一个JTextArea,wr APS为JScrollPane,并通过调用添加到pnl

private JPanel createCenterFrame() { 
    JPanel pnl = new JPanel(); 
    Border raisedBevel = BorderFactory.createRaisedBevelBorder(); 
    Color lineColor = new Color(224, 224, 224); 
    Border lineBorder = BorderFactory.createMatteBorder(5, 5, 5, 5, lineColor); 
    Border loweredBevel = BorderFactory.createLoweredBevelBorder(); 
    Border compoundSetup = BorderFactory.createCompoundBorder(raisedBevel, lineBorder); 
    Border compoundFinal = BorderFactory.createCompoundBorder(compoundSetup, loweredBevel); 
    TitledBorder topFrameTitle = BorderFactory.createTitledBorder(compoundFinal, "Stuff"); 
    topFrameTitle.setTitleJustification(TitledBorder.CENTER); 

    pnl.setBorder(topFrameTitle); 
    pnl.setLayout(new BorderLayout()); 

    JScrollPane scrollPane = new JScrollPane(); 
    scrollPane.setOpaque(false); 
    scrollPane.getViewport().setOpaque(false); 

    JTextArea ta = new JTextArea(); 
    ta.setOpaque(false); 
    ta.setText("This is an example of a transparent text area inside a transparent scroll pane, but you could just as easily wrap a transparent panel into it and get the same result"); 
    ta.setWrapStyleWord(true); 
    ta.setLineWrap(true); 

    scrollPane.setViewportView(ta); 

    pnl.add(scrollPane); 

    pnl.setOpaque(false); 
    return pnl; 
} 

Transparent scroll pane and text area

+0

YAY!再次感谢(MadProgrammer救援!!!)。 swing库有很多我需要学习的方法,geez :) –

+0

@FiddleFreak每个框架都一样:P - 需要学习的地方 – MadProgrammer

+0

对不起再次打扰你,它看起来好像没有通过JScrollPane显示。我应该把这个问题作为一个新问题来解决吗? –