lipsync/trunk/Boare.Lib.Vsq/VsqEventList.cs

137 lines
3.9 KiB
C#

/*
* VsqEventList.cs
* Copyright (c) 2008-2009 kbinani
*
* This file is part of Boare.Lib.Vsq.
*
* Boare.Lib.Vsq is free software; you can redistribute it and/or
* modify it under the terms of the BSD License.
*
* Boare.Lib.Vsq 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.
*/
using System;
using System.Collections.Generic;
using bocoree;
namespace Boare.Lib.Vsq {
/// <summary>
/// 固有ID付きのVsqEventのリストを取り扱う
/// </summary>
[Serializable]
public class VsqEventList {
public Vector<VsqEvent> Events;
private Vector<int> m_ids;
/// <summary>
/// コンストラクタ
/// </summary>
public VsqEventList() {
Events = new Vector<VsqEvent>();
m_ids = new Vector<int>();
}
public VsqEvent findFromID( int internal_id ) {
for ( Iterator itr = Events.iterator(); itr.hasNext(); ){
VsqEvent item = (VsqEvent)itr.next();
if ( item.InternalID == internal_id ) {
return item;
}
}
return null;
}
public void setForID( int internal_id, VsqEvent value ) {
int c = Events.size();
for ( int i = 0; i < c; i++ ) {
if ( Events.get( i ).InternalID == internal_id ) {
Events.set( i, value );
break;
}
}
}
public void sort() {
lock ( this ) {
Collections.sort( Events );
updateIDList();
}
}
public void clear() {
Events.clear();
m_ids.clear();
}
public Iterator iterator() {
updateIDList();
return new ListIterator<VsqEvent>( Events );
}
public void add( VsqEvent item ) {
updateIDList();
int new_id = getNextId( 0 );
item.InternalID = new_id;
Events.add( item );
m_ids.add( new_id );
Collections.sort( Events );
for ( int i = 0; i < Events.size(); i++ ) {
m_ids.set( i, Events.get( i ).InternalID );
}
}
public void removeAt( int index ) {
updateIDList();
Events.removeElementAt( index );
m_ids.removeElementAt( index );
}
private int getNextId( int next ) {
updateIDList();
int index = -1;
Vector<int> current = new Vector<int>( m_ids );
int nfound = 0;
while ( true ) {
index++;
if ( !current.contains( index ) ) {
nfound++;
if ( nfound == next + 1 ) {
return index;
} else {
current.add( index );
}
}
}
}
public int getCount() {
return Events.size();
}
public VsqEvent getElement( int index ) {
return Events.get( index );
}
public void setElement( int index, VsqEvent value ) {
Events.set( index, value );
}
public void updateIDList() {
if ( m_ids.size() != Events.size() ) {
m_ids.clear();
for ( int i = 0; i < Events.size(); i++ ) {
m_ids.add( Events.get( i ).InternalID );
}
} else {
for ( int i = 0; i < Events.size(); i++ ) {
m_ids.set( i, Events.get( i ).InternalID );
}
}
}
}
}