Spec-Zone .ru
спецификации, руководства, описания, API
|
001/* 002 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. 003 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 004 * 005 * This code is free software; you can redistribute it and/or modify it 006 * under the terms of the GNU General Public License version 2 only, as 007 * published by the Free Software Foundation. Oracle designates this 008 * particular file as subject to the "Classpath" exception as provided 009 * by Oracle in the LICENSE file that accompanied this code. 010 * 011 * This code is distributed in the hope that it will be useful, but WITHOUT 012 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 013 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 014 * version 2 for more details (a copy is included in the LICENSE file that 015 * accompanied this code). 016 * 017 * You should have received a copy of the GNU General Public License version 018 * 2 along with this work; if not, write to the Free Software Foundation, 019 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 020 * 021 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 022 * or visit www.oracle.com if you need additional information or have any 023 * questions. 024 */ 025package javafx.collections; 026 027import com.sun.javafx.collections.ArrayListenerHelper; 028import javafx.beans.InvalidationListener; 029 030/** 031 * Abstract class that serves as a base class for {@link ObservableArray} implementations. 032 * The base class provides listener handling functionality by implementing 033 * {@code addListener} and {@code removeListener} methods. 034 * {@link #fireChange(boolean, int, int) } method is provided 035 * for notifying the listeners. 036 * @param <T> actual array instance type 037 * @see ObservableArray 038 * @see ArrayChangeListener 039 * @since 8.0 040 */ 041public abstract class ObservableArrayBase<T extends ObservableArray<T>> implements ObservableArray<T> { 042 043 private ArrayListenerHelper<T> listenerHelper; 044 045 @Override public final void addListener(InvalidationListener listener) { 046 listenerHelper = ArrayListenerHelper.<T>addListener(listenerHelper, (T) this, listener); 047 } 048 049 @Override public final void removeListener(InvalidationListener listener) { 050 listenerHelper = ArrayListenerHelper.removeListener(listenerHelper, listener); 051 } 052 053 @Override public final void addListener(ArrayChangeListener<T> listener) { 054 listenerHelper = ArrayListenerHelper.<T>addListener(listenerHelper, (T) this, listener); 055 } 056 057 @Override public final void removeListener(ArrayChangeListener<T> listener) { 058 listenerHelper = ArrayListenerHelper.removeListener(listenerHelper, listener); 059 } 060 061 /** 062 * Notifies all listeners of a change 063 * @param change 064 */ 065 protected final void fireChange(boolean sizeChanged, int from, int to) { 066 ArrayListenerHelper.fireValueChangedEvent(listenerHelper, sizeChanged, from, to); 067 } 068}