/* * TexturesCatalog.java 5 oct. 2006 * * Sweet Home 3D, Copyright (c) 2007 Emmanuel PUYBARET / eTeks <info@eteks.com> * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation; either version 2 of the License, or (at your option) any later * version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program; if not, write to the Free Software Foundation, Inc., 59 Temple * Place, Suite 330, Boston, MA 02111-1307 USA */ package com.eteks.sweethome3d.model; import java.util.ArrayList; import java.util.Collections; import java.util.List; /** * Textures catalog. * @author Emmanuel Puybaret */ public class TexturesCatalog { private List<TexturesCategory> categories = new ArrayList<TexturesCategory>(); private boolean sorted; private final CollectionChangeSupport<CatalogTexture> texturesChangeSupport = new CollectionChangeSupport<CatalogTexture>(this); /** * Returns the categories list sorted by name. * @return an unmodifiable list of categories. */ public List<TexturesCategory> getCategories() { checkCategoriesSorted(); return Collections.unmodifiableList(this.categories); } /** * Checks categories are sorted. */ private void checkCategoriesSorted() { if (!this.sorted) { Collections.sort(this.categories); this.sorted = true; } } /** * Returns the count of categories in this catalog. */ public int getCategoriesCount() { return this.categories.size(); } /** * Returns the category at a given <code>index</code>. */ public TexturesCategory getCategory(int index) { checkCategoriesSorted(); return this.categories.get(index); } /** * Adds the texture <code>listener</code> in parameter to this catalog. */ public void addTexturesListener(CollectionListener<CatalogTexture> listener) { this.texturesChangeSupport.addCollectionListener(listener); } /** * Removes the texture <code>listener</code> in parameter from this catalog. */ public void removeTexturesListener(CollectionListener<CatalogTexture> listener) { this.texturesChangeSupport.removeCollectionListener(listener); } /** * Adds a category to this catalog. * @param category the textures category to add. * @throws IllegalHomonymException if a category with same name as the one in * parameter already exists in this catalog. */ private void add(TexturesCategory category) { if (this.categories.contains(category)) { throw new IllegalHomonymException( category.getName() + " already exists in catalog"); } this.categories.add(category); this.sorted = false; } /** * Adds <code>texture</code> of a given <code>category</code> to this catalog. * Once the <code>texture</code> is added, texture listeners added to this catalog will receive a * {@link CollectionListener#collectionChanged(CollectionEvent) collectionChanged} notification. * @param category the category of the texture. * @param texture a texture. */ public void add(TexturesCategory category, CatalogTexture texture) { int index = this.categories.indexOf(category); // If category doesn't exist yet, add it to categories if (index == -1) { category = new TexturesCategory(category.getName()); add(category); } else { category = this.categories.get(index); } // Add current texture to category list category.add(texture); this.texturesChangeSupport.fireCollectionChanged(texture, category.getIndexOfTexture(texture), CollectionEvent.Type.ADD); } /** * Deletes the <code>texture</code> from this catalog. * If then texture category is empty, it will be removed from the categories of this catalog. * Once the <code>texture</code> is deleted, texture listeners added to this catalog will receive a * {@link CollectionListener#collectionChanged(CollectionEvent) collectionChanged} notification. * @param texture a texture. */ public void delete(CatalogTexture texture) { TexturesCategory category = texture.getCategory(); // Remove texture from its category if (category != null) { int textureIndex = category.getIndexOfTexture(texture); if (textureIndex >= 0) { category.delete(texture); if (category.getTexturesCount() == 0) { // Make a copy of the list to avoid conflicts in the list returned by getCategories this.categories = new ArrayList<TexturesCategory>(this.categories); this.categories.remove(category); } this.texturesChangeSupport.fireCollectionChanged(texture, textureIndex, CollectionEvent.Type.DELETE); return; } } throw new IllegalArgumentException("catalog doesn't contain texture " + texture.getName()); } }