/*
* SIP Communicator, the OpenSource Java VoIP and Instant Messaging client.
*
* Distributable under LGPL license.
* See terms of license at gnu.org.
*/
package net.java.sip.communicator.impl.protocol.icq;
import java.io.*;
import java.util.*;
import net.java.sip.communicator.service.protocol.*;
import net.java.sip.communicator.service.resources.*;
import net.java.sip.communicator.util.*;
import org.osgi.framework.*;
/**
* Represents the Aim protocol icon. Implements the ProtocolIcon
* interface in order to provide an aim icon image in two different sizes.
*
* @author Yana Stamcheva
*/
public class ProtocolIconAimImpl
implements ProtocolIcon
{
private static Logger logger = Logger.getLogger(ProtocolIconAimImpl.class);
private static ResourceManagementService resourcesService;
/**
* A hash table containing the protocol icon in different sizes.
*/
private static Hashtable iconsTable
= new Hashtable();
static
{
iconsTable.put(ProtocolIcon.ICON_SIZE_16x16,
getImageInBytes("service.protocol.aim.AIM_16x16"));
iconsTable.put(ProtocolIcon.ICON_SIZE_32x32,
getImageInBytes("service.protocol.aim.AIM_32x32"));
iconsTable.put(ProtocolIcon.ICON_SIZE_48x48,
getImageInBytes("service.protocol.aim.AIM_48x48"));
iconsTable.put(ProtocolIcon.ICON_SIZE_64x64,
getImageInBytes("service.protocol.aim.AIM_64x64"));
}
/**
* Implements the ProtocolIcon.getSupportedSizes() method. Returns
* an iterator to a set containing the supported icon sizes.
* @return an iterator to a set containing the supported icon sizes
*/
public Iterator getSupportedSizes()
{
return iconsTable.keySet().iterator();
}
/**
* Returns TRUE if a icon with the given size is supported, FALSE-otherwise.
*
* @return TRUE if a icon with the given size is supported, FALSE-otherwise.
*/
public boolean isSizeSupported(String iconSize)
{
return iconsTable.containsKey(iconSize);
}
/**
* Returns the icon image in the given size.
* @param iconSize the icon size; one of ICON_SIZE_XXX constants
*/
public byte[] getIcon(String iconSize)
{
return iconsTable.get(iconSize);
}
/**
* Returns the icon image used to represent the protocol connecting state.
* @return the icon image used to represent the protocol connecting state
*/
public byte[] getConnectingIcon()
{
return getImageInBytes("aimConnectingIcon");
}
/**
* Returns the byte representation of the image corresponding to the given
* identifier.
*
* @param imageID the identifier of the image
* @return the byte representation of the image corresponding to the given
* identifier.
*/
private static byte[] getImageInBytes(String imageID)
{
InputStream in = getResources().
getImageInputStream(imageID);
if (in == null)
return null;
byte[] image = null;
try
{
image = new byte[in.available()];
in.read(image);
}
catch (IOException e)
{
logger.error("Failed to load image:" + imageID, e);
}
return image;
}
public static ResourceManagementService getResources()
{
if (resourcesService == null)
{
ServiceReference serviceReference = IcqActivator.bundleContext
.getServiceReference(ResourceManagementService.class.getName());
if(serviceReference == null)
return null;
resourcesService
= (ResourceManagementService)IcqActivator.bundleContext
.getService(serviceReference);
}
return resourcesService;
}
}