Pokročilé řazení nodů v JTree – Java – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

Pokročilé řazení nodů v JTree – Java – Fórum – Programujte.comPokročilé řazení nodů v JTree – Java – Fórum – Programujte.com

 

Hledá se programátor! Plat 1 800 € + bonusy (firma Boxmol.com)
Alfréd
~ Anonymní uživatel
1 příspěvek
15. 3. 2014   #1
-
0
-

Ahoj,

zkouším si něco v JTree a narazil jsem na problém v řazení nodů. Nemám problém to celý seřadit podle abecedy, ale mám problém to seřadit tak, aby nody, které mají nějaké "childy" byli seřazený jako první podle abecedy a potom ostatní nody bez childů podle abecedy.

např. mám takovou struktůr, kterou se snažím seřadit

+ Bagr 3
  - aaa
  - zzz
  + SubBagr 2
    - ccc
    - aaa
  - fff
  + SubBagr 1
    - ggg
+ Bagr 1
  - uuu
  + SubBagr 1
    - bbb
    - aaa
+ Bagr 2
  + SubBagr 1
    - ttt
    + SubSubBagr 1
      - iii
      + SubSubSubBagr 1
      - ppp
      - aaa
      + SuperBagr
        - xxx


A potřebuju nebo se snažim to seřadit ve stylu adresářů, aby výsledek vypadat takto: 

+ Bagr 1
  + SubBagr 1
    - aaa
    - ccc
  + SubBagr 2
    - ggg
  - aaa
  - fff
  - zzz
+ Bagr 2
  + SubBagr 1
    - aaa
    - bbb
  - uuu
+ Bagr 3
  + SubBagr 1
    + SubSubBagr 1
      + SubSubSubBagr 1
        + SuperBagr
          - xxx
        - aaa
        - ppp
      - iii
    - ttt


Prostě aby vše bylo podle abecedy a ještě jako první adresáře a potom "soubory" kde jak pro adresáře tak soubory se použije vlastní řazení (asi teda). Hlavní rootNode mám, akorát je takto neseřazený

Moc by mi pomohla pomoc, docela dlouho se s tím seru a nějak né a né to vyřešit.

Díky :)

Nahlásit jako SPAM
IP: 213.168.183.–
Reklama
Reklama
z
~ Anonymní uživatel
268 příspěvků
15. 3. 2014   #2
-
0
-

Takže nejdřív jde o to, jestli ten node má childy a až pak o to, jak se jmenuje. Tak to přesně tak napiš   Takhle nějak:

if (!prvni.isLeaf() && druhy.isLeaf()) {
    return -1;
} else if (prvni.isLeaf() && !druhy.isLeaf()) {
    return 1;
} else {
    return prvni.nazev.compare(druhy.nazev);
}
Nahlásit jako SPAM
IP: 88.101.8.–
Flowy0
Věrný člen
16. 3. 2014   #3
-
0
-

   

int result = 0;
result = this.countLeafs() - other.countLeafs();
if (result == 0) {
	result = this.compareTo(other);  //odkaz na radenie podla abecedy
}
return result;
Nahlásit jako SPAM
IP: 95.102.43.–
https://github.com/Flowy
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 44 hostů

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032016 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý