|
Eclipse Platform Release 3.0 | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.eclipse.swt.dnd.Transfer org.eclipse.swt.dnd.ByteArrayTransfer
The class ByteArrayTransfer provides a platform specific mechanism for converting a java byte[] to a platform specific representation of the byte array and vice versa. See Transfer for additional information.
ByteArrayTransfer is never used directly but is sub-classed by transfer agents that convert between data in a java format such as a String and a platform specific byte array.
If the data you are converting does not map to a byte[], you should sub-class Transfer directly and do your own mapping to a platform data type.
The following snippet shows a sublcass of ByteArrayTransfer that transfers data defined by the class MyType.
public class MyType { public String fileName; public long fileLength; public long lastModified; }
public class MyTypeTransfer extends ByteArrayTransfer { private static final String MYTYPENAME = "my_type_name"; private static final int MYTYPEID = registerType(MYTYPENAME); private static MyTypeTransfer _instance = new MyTypeTransfer(); private MyTypeTransfer() {} public static MyTypeTransfer getInstance () { return _instance; } public void javaToNative (Object object, TransferData transferData) { if (object == null || !(object instanceof MyType[])) return; if (isSupportedType(transferData)) { MyType[] myTypes = (MyType[]) object; try { // write data to a byte array and then ask super to convert to pMedium ByteArrayOutputStream out = new ByteArrayOutputStream(); DataOutputStream writeOut = new DataOutputStream(out); for (int i = 0, length = myTypes.length; i < length; i++){ byte[] buffer = myTypes[i].fileName.getBytes(); writeOut.writeInt(buffer.length); writeOut.write(buffer); writeOut.writeLong(myTypes[i].fileLength); writeOut.writeLong(myTypes[i].lastModified); } byte[] buffer = out.toByteArray(); writeOut.close(); super.javaToNative(buffer, transferData); } catch (IOException e) { } } } public Object nativeToJava(TransferData transferData){ if (isSupportedType(transferData)) { byte[] buffer = (byte[])super.nativeToJava(transferData); if (buffer == null) return null; MyType[] myData = new MyType[0]; try { ByteArrayInputStream in = new ByteArrayInputStream(buffer); DataInputStream readIn = new DataInputStream(in); while(readIn.available() > 20) { MyType datum = new MyType(); int size = readIn.readInt(); byte[] name = new byte[size]; readIn.read(name); datum.fileName = new String(name); datum.fileLength = readIn.readLong(); datum.lastModified = readIn.readLong(); MyType[] newMyData = new MyType[myData.length + 1]; System.arraycopy(myData, 0, newMyData, 0, myData.length); newMyData[myData.length] = datum; myData = newMyData; } readIn.close(); } catch (IOException ex) { return null; } return myData; } return null; } protected String[] getTypeNames(){ return new String[]{MYTYPENAME}; } protected int[] getTypeIds(){ return new int[] {MYTYPEID}; } }
Constructor Summary | |
ByteArrayTransfer()
|
Method Summary | |
TransferData[] | getSupportedTypes()
Returns a list of the platform specific data types that can be converted using this transfer agent. |
boolean | isSupportedType(TransferData transferData)
Returns true if the TransferData data type can be converted using this transfer agent. |
protected void | javaToNative(Object object,
TransferData transferData)
This implementation of javaToNative converts a java byte[] to a platform specific representation. |
protected Object | nativeToJava(TransferData transferData)
This implementation of nativeToJava converts a platform specific representation of a byte array to a java byte[]. |
Methods inherited from class org.eclipse.swt.dnd.Transfer |
getTypeIds, getTypeNames, registerType |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
public ByteArrayTransfer()
Method Detail |
public TransferData[] getSupportedTypes()
Only the data type fields of the TransferData objects are filled in.
public boolean isSupportedType(TransferData transferData)
protected void javaToNative(Object object, TransferData transferData)
protected Object nativeToJava(TransferData transferData)
|
Eclipse Platform Release 3.0 | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
Guidelines for using Eclipse APIs.
Copyright (c) IBM Corp. and others 2000, 2004. All rights reserved.