Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-06-2010, 21: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, 22: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, 22: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, 22: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, 22: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 05-06-2010, 23: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 05-06-2010, 23: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 05-06-2010, 23: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 05-06-2010, 23: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 05-06-2010, 23: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 05-06-2010, 23: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 05-06-2010, 23: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, 00: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, 08: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


Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Anche T-Mobile abbandona VMware e migra ...
In Italia crescono gli investimenti nell...
Samsung combina IA e quantum computing p...
Anthropic ammette: Claude Code usa un ap...
L'IA costa sempre di più: AWS aum...
Google prepara il blocco delle app non v...
Amazfit aggiorna il Cheetah 2 Ultra: ric...
L'FAA apre ai voli commerciali supersoni...
Amazon ha già abbastanza satelliti per a...
A2A ed Equinix uniscono le forze per rec...
Apple ha creato la crisi delle memorie? ...
GPU subito in cambio di una quota dei ri...
Firefly Aerospace potrà lanciare ...
Intesa Sanpaolo sposta i sistemi IT core...
Visa, Mastercard e Coinbase lanciano Ope...
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: 06:04.


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