2013-04-07 9 views
7

मैं अपने जेटीबल के सेल को चयनित पैनलों के साथ क्षैतिज रूप से गठबंधन करना चाहता हूं।
मेरी समस्या का वर्णन करने के लिए यहां एक एसएससीसीई है। किसी भी मदद के लिए धन्यवाद।
प्रोग्रामिंग रूप से स्क्रॉलिंग

public class TableCellAlignment { 

    private final static int MAX = 50; 
    private static SelectablePanel[] selectablePanels = new SelectablePanel[MAX]; 
    private static JScrollPane slaveScrollPane = new JScrollPane(); 
    private static JScrollPane masterScrollPane = new JScrollPane(); 
    private static JTable slaveTable = new JTable(); 

    /** 
    * @param args the command line arguments 
    */ 
    public static void main(String[] args) { 
     EventQueue.invokeLater(new Runnable() { 
      @Override 
      public void run() { 
       new TableCellAlignment().createGUI(); 
      } 
     }); 
    } 

    private static void createGUI() { 
     JFrame f = new JFrame("TableCellAlignment"); 
     f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
     JPanel masterPanel = new JPanel(new GridLayout(MAX, 1)); 
     Integer[][] objs = new Integer[MAX][1]; 
     for (int i = 0; i < MAX; i++) { 
      objs[i][0] = new Integer(i); 
      SelectablePanel masterSelectablePanel = new SelectablePanel(); 
      masterSelectablePanel.setNum(i); 
      selectablePanels[i] = masterSelectablePanel; 
      masterPanel.add(masterSelectablePanel); 
     } 
     DefaultTableModel model = new DefaultTableModel(objs, new Object[]{"Column1"}); 
     model.addTableModelListener(new TableModelListener() { 
      @Override 
      public void tableChanged(TableModelEvent e) { 
       EventQueue.invokeLater(new Runnable() { 
        @Override 
        public void run() { 
         slaveTable.setRowHeight(20); 
        } 
       }); 
      } 
     }); 
     model.addRow(objs); 
     slaveTable.setModel(model); 
     final JPanel p = new JPanel(new GridLayout(1, 2)); 
     masterScrollPane.setViewportView(masterPanel); 
     slaveScrollPane.setViewportView(slaveTable); 
     p.add(masterScrollPane); 
     p.add(slaveScrollPane); 
     f.add(p); 

     f.setSize(400, 200); 
     f.setLocationRelativeTo(null); 
     f.setVisible(true); 
    } 

    private static class SelectablePanel extends JPanel { 

     private PropertyChangeSupport cs; 
     private int num; 
     private boolean selected = false; 

     public SelectablePanel() { 
      cs = new PropertyChangeSupport(this); 
      cs.addPropertyChangeListener(new SelectedPropertyChangeListener()); 
      addMouseListener(new MouseAdapter() { 
       @Override 
       public void mouseClicked(MouseEvent e) { 
        setSelected(true); 
       } 
      }); 
     } 

     public int getNum() { 
      return num; 
     } 

     public void setNum(int num) { 
      this.num = num; 
     } 

     public boolean isSelected() { 
      return selected; 
     } 

     @Override 
     protected void paintComponent(Graphics g) { 
      super.paintComponent(g); 
      if (selected) { 
       Color c = g.getColor(); 
       g.setColor(Color.blue); 
       g.fillRect(0, 0, getWidth(), getHeight()); 
       g.setColor(Color.white); 
       FontMetrics fm = g.getFontMetrics(); 
       g.drawString("" + getNum(), getWidth()/2, (getHeight() + (fm.getAscent() - fm.getDescent()))/2); 
       g.setColor(c); 
      } 
     } 

     @Override 
     public Dimension getPreferredSize() { 
      return new Dimension(100, 20); 
     } 

     public void setSelected(boolean selected) { 
      boolean oldVal = isSelected(); 
      this.selected = selected; 
      cs.firePropertyChange("selected", oldVal, selected); 
      repaint(); 
     } 

     private class SelectedPropertyChangeListener implements PropertyChangeListener { 

      @Override 
      public void propertyChange(PropertyChangeEvent evt) { 
       if (evt.getPropertyName().equals("selected")) { 
        boolean selected = (boolean) evt.getNewValue(); 
        if (selected) { 
         for (int i = 0; i < MAX; i++) { 
          SelectablePanel masterSelectablePanel = selectablePanels[i]; 
          if (i != getNum() && masterSelectablePanel.isSelected()) { 
           masterSelectablePanel.setSelected(false); 
          } 

         } 
         slaveTable.setRowSelectionInterval(getNum(), getNum()); 
         final JViewport viewport = slaveScrollPane.getViewport(); 
         Rectangle rect = new Rectangle(getBounds().x, getBounds().y, 1, 1); 
         Rectangle r2 = viewport.getVisibleRect(); 
         slaveTable.scrollRectToVisible(new Rectangle(rect.x, rect.y, (int)r2.getWidth(), (int)r2.getHeight())); 
        } 
       } 
      } 
     } 
    } 
} 
+0

बीटीडब्ल्यू, एसएससीसीई प्रदान करने के लिए +1। बीटीडब्लू: असली दुनिया कोड में, आप सेट में प्रतिबिंबित करेंगे श्रोता नहीं चुना। लेकिन फिर, यह केवल एक उदाहरण है :-) – kleopatra

+0

ठीक है, टिप के लिए धन्यवाद। मुझे लगता है कि मैं इसे जेएलिस्ट का उपयोग करने के लिए किसी भी तरह संपादित कर दूंगा, मुझे लगता है कि एमकोरबेल ने मुझे यह स्पष्ट करने के लिए सुझाव दिया है, लेकिन इसकी पोस्ट हटा दी गई है। आपके उत्तर के लिए धन्यवाद। – jerome

+0

जैसा कि मैंने टिप्पणी की थी (हटाई गई टिप्पणी) पिछले सप्ताह पर सबसे अच्छा सवाल ...., फिर मैंने केवल टिप्पणी की, [उत्तर चारों ओर हैं, कुछ अच्छी गुणवत्ता वाले हैं, लेकिन यहां खोजना है कि कैसे खोजना है] (http: // stackoverflow। कॉम/प्रश्न/15868553/फिट-ऑल-घटकों-से-जेफ्रेम-टू-वास्तविक-आकार-ऑफ-विंडो/15868588 # टिप्पणी 22600617_15868588), JComponets को JList या JTable में न डालें, केवल इसका विवरण, स्ट्रिंग मान के लिए जेबटन, XxxRenderer के लिए यह नौकरी (चित्रकला जेबटन) को देता है, उसके उत्तर को आपके अपवोट – mKorbel

उत्तर

3

यह बुनियादी गणित है और यह व्यूपोर्ट के लिए उपयोग की आवश्यकता नहीं है:

// in the isSelected block of the propertyChangeListener: 
JComponent current = (JComponent) evt.getSource(); 
slaveTable.setRowSelectionInterval(getNum(), getNum()); 
// get the cellRect of the selected cell 
Rectangle cellRect = slaveTable.getCellRect(getNum(), 0, false); 
// get the bounds of the selected panel 
Rectangle panelRect = current.getBounds(); 
// get the visible rect of the selected panel's parent 
Rectangle parentVisibleRect = ((JComponent) current.getParent()).getVisibleRect(); 
// the diff above the current (to the parent's visible rect) 
int aboveCurrent = panelRect.y - parentVisibleRect.y; 
// translate the cell rect 
cellRect.y = Math.max(cellRect.y - aboveCurrent, 0); 
// adjust size to slaveTable's visible height 
cellRect.height = slaveTable.getVisibleRect().height; 
slaveTable.scrollRectToVisible(cellRect); 

नोट इस स्निपेट मानता है कि कि दोनों पैनल के माता-पिता और तालिका के दृश्य की व्यूपोर्ट एक ही आकार है, तो या तो हटा दें तालिका से शीर्षलेख, या पैनल के scrollPane में एक शीर्षलेख जोड़ें, या एक लेआउटमैनेजर का उपयोग करें जो दो scrollPanes के व्यूपोर्ट को संरेखित कर सकता है।

3

व्यूपोर्ट। setViewPosition (पीटी); as shown here

+0

के लिए रोते हुए जवाब देता है कि उदाहरण सही है (खुद में आश्चर्यचकित, java2s.com से आ रहा है ;-) लेकिन इस प्रश्न के संदर्भ में, पहुंचने की कोई आवश्यकता नहीं है व्यूपोर्ट :-) – kleopatra

संबंधित मुद्दे