Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-06-2010, 22:44   #1
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
[Java] Problema posizionamento JPanel in JPanel

Salve a tutti. Vorrei inserire dei piccoli JPanel che hanno una dimensione fissa, all'interno di un JPanel, e vorrei fare in modo che quelli che si trovano all'interno, vadino a capo quando lo spazio della finestra finisce, ed evitare che questi continuino a stare uno affianco all'altro fino al punto di creare una lunga barra da scrollare in orizzontale.

Qualche idea?
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
Old 05-06-2010, 23:42   #2
*andre*
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 1071
Quote:
Originariamente inviato da UnknownSoldier Guarda i messaggi
Salve a tutti. Vorrei inserire dei piccoli JPanel che hanno una dimensione fissa, all'interno di un JPanel, e vorrei fare in modo che quelli che si trovano all'interno, vadino a capo quando lo spazio della finestra finisce, ed evitare che questi continuino a stare uno affianco all'altro fino al punto di creare una lunga barra da scrollare in orizzontale.

Qualche idea?
potresti usare un gridlayout per il panel contenitore, che dispone gli altri secondo una griglia e li inserisce per default da sinistra a destra andando a capo quando raggiunge il numero di colonne che hai impostato. http://java.sun.com/javase/6/docs/api/ qui cerca gridlayout e c'è tutto spiegato
__________________
Affari: ariakasneverborne, PanCar, Luk@°°°, Fabio310, kintaro oe, krike, fabry180384, dariox am2, chiadoz, windsofchange, dado1979, Rudyduca, aleforumista, Sheva77
*andre* è offline   Rispondi citando il messaggio o parte di esso
Old 05-06-2010, 23:47   #3
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
Grazie ma io vorrei che i JPanel andassero a capo quando non c'è più spazio nella finestra! E se allargo la finestra questi si adattano alle nuove dimensioni.
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
Old 05-06-2010, 23:48   #4
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Un semplice flowlayout non la fa già di suo?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 05-06-2010, 23:58   #5
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
Purtroppo non è così, continua ad aggiungermi i JPanel uno dopo l'altro senza mai andare a capo...
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:00   #6
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Metti un flowlayout con allineamento a sinistra, va a capo per forza quando finisce lo spazio.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:11   #7
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
Ho provato a non utilizzare lo JScrollPane e funziona! Però purtroppo in questo modo non compare la barra laterale per scrollare o_O
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:25   #8
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
ah ecco, è un problema del JScrollPane (usi quello vero?) che non restituisce la dimensione preferredsize corretta.

Per risolvere prova a settare (setPreferredSize) la dimensione dinamicamente quando il panello viene ridimensionato.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:31   #9
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
Quote:
Originariamente inviato da MEMon Guarda i messaggi
ah ecco, è un problema del JScrollPane (usi quello vero?) che non restituisce la dimensione preferredsize corretta.

Per risolvere prova a settare (setPreferredSize) la dimensione dinamicamente quando il panello viene ridimensionato.
Ma se imposto le dimensioni, sono costretto a fissare anche l'altezza, che varia in base agli elementi contenuti!
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:39   #10
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Hai ragione non ci avevo pensato.

Potresti allora utilizzare una JScrollBar e scrivere tu il codice per lo scroll, come la vedi?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:45   #11
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
Quote:
Originariamente inviato da MEMon Guarda i messaggi
Hai ragione non ci avevo pensato.

Potresti allora utilizzare una JScrollBar e scrivere tu il codice per lo scroll, come la vedi?
Cioè? o_O
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 00:56   #12
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Invece di usare uno scroll pane usi una JScrollbar e scrivi a mano il codice per fare lo scroll, in pratica ti fai un componente apposta per quello che ti serve.

La scrollbar quando viene mossa lancia l'evento adjustmentValueChanged, te devi catturare quell'evento e "scrollare" il tuo pannello con flowlayout.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 01:54   #13
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Sei incappato nel mitico problema del FlowLayout e del JScrollPane. E' veramente un incrocio straordinario di caratteri particolari.

Capita che il JViewport del JScrollPane faccia crescere a piacere, in larghezza, il componente incapsulato che usi un FlowLayout.

Una soluzione rapida sta nel fissare la dimensione del componente che usa FlowLayout (con setPreferredSize, che di norma non fissa ma in un JViewport ha questo effetto).

Una soluzione meno rapida ma più flessibile consiste nel creare un simil-FlowLayout che corregga quel conflitto.

Negli androni di un hard disk ho trovato questo LayoutManager che, se non ricordo male, affrontava esattamente quel problema. Non ricordo però se l'avesse anche risolto. Tentar non nuoce. Anzichè dire:

x = new JPanel() // o new JPanel(new FlowLayout())

basta dire:

x = new JPanel(TableLayout.newInstance());

Segue codicillo.

Codice:
package it.tukano.jupiter.modules.basic.common;

import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.Insets;
import java.awt.LayoutManager;
import java.util.LinkedList;

/**
 * A layout manager similar to FlowLayout but that will not cause the container to
 * grow in width.
 * @author pgi
 */
public class TableLayout implements LayoutManager {

    /** Creator */
    public static TableLayout newInstance() {
        return new TableLayout();
    }

    /** Default empty constructor, not used. */
    protected TableLayout() {
    }

    /**
     * Unused
     * @param name
     * @param comp
     */
    public void addLayoutComponent(String name, Component comp) {
    }

    /**
     * Unused
     * @param comp
     */
    public void removeLayoutComponent(Component comp) {
    }

    /**
     * The preferred layout size depends upon the actual width of the container.
     * The size is the width and the minumum height sufficient to display all
     * the children of the container along their preferred size.
     * @param parent
     * @return the preferred size for the parent container.
     */
    public Dimension preferredLayoutSize(Container parent) {
        synchronized (parent.getTreeLock()) {
            int width = parent.getWidth();
            int height = parent.getHeight();
            Insets margins = parent.getInsets();
            int availableWidth = width - margins.left - margins.right;
            Component[] children = parent.getComponents();

            RowBuilder rowBuilder = new RowBuilder(availableWidth);
            for (Component c : children) {
                rowBuilder.push(c);
            }

            Dimension dim = rowBuilder.computeSize();
            dim.width += margins.left + margins.right;
            dim.height += margins.top + margins.bottom;
            return dim;
        }
    }

    /**
     * Returns the preferred layout size.
     * @param parent the component to layout
     * @return the minimum layout size.
     */
    public Dimension minimumLayoutSize(Container parent) {
        return preferredLayoutSize(parent);
    }

    /**
     * Assign bounds to the child of the given container.
     * @param parent the container to layout
     */
    public void layoutContainer(Container parent) {
        synchronized (parent.getTreeLock()) {

            int width = parent.getWidth();
            int height = parent.getHeight();
            Insets margins = parent.getInsets();

            int availableWidth = width - margins.left - margins.right;
            int availableHeight = height - margins.top - margins.bottom;

            RowBuilder rowBuilder = new RowBuilder(availableWidth);

            for (Component c : parent.getComponents()) {
                rowBuilder.push(c);
            }

            rowBuilder.assignBounds(margins.left, margins.top);
        }
    }

    private static class RowBuilder {

        private LinkedList<Row> rows = new LinkedList<Row>();
        private int currentX;
        private final int width;
        private Row currentRow = new Row();

        private RowBuilder(int width) {
            this.width = width;
            rows.add(currentRow);
        }

        void push(Component c) {
            Dimension dim = c.getPreferredSize();
            if (currentX + dim.width >= width) {
                currentRow = new Row();
                rows.add(currentRow);
                currentX = 0;
            }
            currentX += dim.width;
            currentRow.add(c);
        }

        void assignBounds(int originX, int originY) {
            int y = originY;
            for (Row r : rows) {
                r.assignBounds(originX, y);
                y += r.getHeight();
            }
        }

        Dimension computeSize() {
            Dimension dim = new Dimension();
            for (Row r : rows) {
                dim.width = Math.max(dim.width, r.getWidth());
                dim.height += r.getHeight();
            }
            return dim;
        }
    }

    private static class Row {

        private LinkedList<Component> components = new LinkedList<Component>();
        private int height = 0;
        private int width = 0;

        void assignBounds(int originX, int originY) {
            int x = originX;
            for (Component c : components) {
                Dimension dim = c.getPreferredSize();
                c.setBounds(x, originY, dim.width, dim.height);
                x += dim.width;
            }
        }

        void add(Component c) {
            Dimension dim = c.getPreferredSize();
            components.add(c);
            height = Math.max(height, dim.height);
            width += dim.width;
        }

        int getWidth() {
            return width;
        }

        int getHeight() {
            return height;
        }
    }
}
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2010, 09:11   #14
UnknownSoldier
Member
 
Iscritto dal: Aug 2008
Messaggi: 210
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Sei incappato nel mitico problema del FlowLayout e del JScrollPane. E' veramente un incrocio straordinario di caratteri particolari.

Capita che il JViewport del JScrollPane faccia crescere a piacere, in larghezza, il componente incapsulato che usi un FlowLayout.

Una soluzione rapida sta nel fissare la dimensione del componente che usa FlowLayout (con setPreferredSize, che di norma non fissa ma in un JViewport ha questo effetto).

Una soluzione meno rapida ma più flessibile consiste nel creare un simil-FlowLayout che corregga quel conflitto.

Negli androni di un hard disk ho trovato questo LayoutManager che, se non ricordo male, affrontava esattamente quel problema. Non ricordo però se l'avesse anche risolto. Tentar non nuoce. Anzichè dire:

x = new JPanel() // o new JPanel(new FlowLayout())

basta dire:

x = new JPanel(TableLayout.newInstance());

Segue codicillo.

Codice:
package it.tukano.jupiter.modules.basic.common;

import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.Insets;
import java.awt.LayoutManager;
import java.util.LinkedList;

/**
 * A layout manager similar to FlowLayout but that will not cause the container to
 * grow in width.
 * @author pgi
 */
public class TableLayout implements LayoutManager {

    /** Creator */
    public static TableLayout newInstance() {
        return new TableLayout();
    }

    /** Default empty constructor, not used. */
    protected TableLayout() {
    }

    /**
     * Unused
     * @param name
     * @param comp
     */
    public void addLayoutComponent(String name, Component comp) {
    }

    /**
     * Unused
     * @param comp
     */
    public void removeLayoutComponent(Component comp) {
    }

    /**
     * The preferred layout size depends upon the actual width of the container.
     * The size is the width and the minumum height sufficient to display all
     * the children of the container along their preferred size.
     * @param parent
     * @return the preferred size for the parent container.
     */
    public Dimension preferredLayoutSize(Container parent) {
        synchronized (parent.getTreeLock()) {
            int width = parent.getWidth();
            int height = parent.getHeight();
            Insets margins = parent.getInsets();
            int availableWidth = width - margins.left - margins.right;
            Component[] children = parent.getComponents();

            RowBuilder rowBuilder = new RowBuilder(availableWidth);
            for (Component c : children) {
                rowBuilder.push(c);
            }

            Dimension dim = rowBuilder.computeSize();
            dim.width += margins.left + margins.right;
            dim.height += margins.top + margins.bottom;
            return dim;
        }
    }

    /**
     * Returns the preferred layout size.
     * @param parent the component to layout
     * @return the minimum layout size.
     */
    public Dimension minimumLayoutSize(Container parent) {
        return preferredLayoutSize(parent);
    }

    /**
     * Assign bounds to the child of the given container.
     * @param parent the container to layout
     */
    public void layoutContainer(Container parent) {
        synchronized (parent.getTreeLock()) {

            int width = parent.getWidth();
            int height = parent.getHeight();
            Insets margins = parent.getInsets();

            int availableWidth = width - margins.left - margins.right;
            int availableHeight = height - margins.top - margins.bottom;

            RowBuilder rowBuilder = new RowBuilder(availableWidth);

            for (Component c : parent.getComponents()) {
                rowBuilder.push(c);
            }

            rowBuilder.assignBounds(margins.left, margins.top);
        }
    }

    private static class RowBuilder {

        private LinkedList<Row> rows = new LinkedList<Row>();
        private int currentX;
        private final int width;
        private Row currentRow = new Row();

        private RowBuilder(int width) {
            this.width = width;
            rows.add(currentRow);
        }

        void push(Component c) {
            Dimension dim = c.getPreferredSize();
            if (currentX + dim.width >= width) {
                currentRow = new Row();
                rows.add(currentRow);
                currentX = 0;
            }
            currentX += dim.width;
            currentRow.add(c);
        }

        void assignBounds(int originX, int originY) {
            int y = originY;
            for (Row r : rows) {
                r.assignBounds(originX, y);
                y += r.getHeight();
            }
        }

        Dimension computeSize() {
            Dimension dim = new Dimension();
            for (Row r : rows) {
                dim.width = Math.max(dim.width, r.getWidth());
                dim.height += r.getHeight();
            }
            return dim;
        }
    }

    private static class Row {

        private LinkedList<Component> components = new LinkedList<Component>();
        private int height = 0;
        private int width = 0;

        void assignBounds(int originX, int originY) {
            int x = originX;
            for (Component c : components) {
                Dimension dim = c.getPreferredSize();
                c.setBounds(x, originY, dim.width, dim.height);
                x += dim.width;
            }
        }

        void add(Component c) {
            Dimension dim = c.getPreferredSize();
            components.add(c);
            height = Math.max(height, dim.height);
            width += dim.width;
        }

        int getWidth() {
            return width;
        }

        int getHeight() {
            return height;
        }
    }
}
Grazie mille, FUNZIONA! Certo che è strano il fatto che in Java per avere un effetto del genere bisogna ricorrere a simili stregonerie
UnknownSoldier è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Altman difende l'efficienza energetica d...
Speciale TV 4K in super offerta su Amazo...
Dalle GPU ai processori: la cinese Moore...
Mega sconto Amazon sui robot aspirapolve...
Vi bastano 256GB sullo smartphone? Se s&...
ChatGPT e gli altri assistenti AI sarann...
Per quel che costa è il miglior r...
L'intelligenza artificiale ha reso pi&ug...
L'intelligenza artificiale per lo svilup...
Il sistema di verifica dell'identit&agra...
Ora è ufficiale: Samsung sta per ...
Motorola Edge 70 Fusion: ecco le specifi...
8TB a meno di 170€: il richiestissimo Ha...
Il nuovo MacBook 'low cost' arriver&agra...
Pokémon Rosso Fuoco e Verde Fogli...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 09:15.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v