package ua.stu.scplib.attribute; import java.io.*; import java.text.NumberFormat; import ua.stu.scplib.tools.FloatFormatter; /** * <p>A concrete class specializing {@link com.pixelmed.dicom.Attribute Attribute} for * Float Double (FD) attributes.</p> * * <p>Though an instance of this class may be created * using its constructors, there is also a factory class, {@link com.pixelmed.dicom.AttributeFactory AttributeFactory}.</p> * * @see com.pixelmed.dicom.Attribute * @see com.pixelmed.dicom.AttributeFactory * @see com.pixelmed.dicom.AttributeList * * @author dclunie */ public class FloatDoubleAttribute extends Attribute { double[] values; static int bytesPerValue=8; private void flushCachedCopies() { } /** * <p>Construct an (empty) attribute.</p> * * @param t the tag of the attribute */ public FloatDoubleAttribute(AttributeTag t) { super(t); flushCachedCopies(); values=null; } /** * <p>Read an attribute from an input stream.</p> * * @param t the tag of the attribute * @param vl the value length of the attribute * @param i the input stream * @exception IOException * @exception DicomException */ public FloatDoubleAttribute(AttributeTag t,long vl,DicomInputStream i) throws IOException, DicomException { super(t); doCommonConstructorStuff(vl,i); } /** * <p>Read an attribute from an input stream.</p> * * @param t the tag of the attribute * @param vl the value length of the attribute * @param i the input stream * @exception IOException * @exception DicomException */ public FloatDoubleAttribute(AttributeTag t,Long vl,DicomInputStream i) throws IOException, DicomException { super(t); doCommonConstructorStuff(vl.longValue(),i); } /** * @param vl * @param i * @exception IOException * @exception DicomException */ private void doCommonConstructorStuff(long vl,DicomInputStream i) throws IOException, DicomException { flushCachedCopies(); if (vl%bytesPerValue != 0) throw new DicomException("incorrect value length for VR "+getVR()); int vm=(int)(vl/bytesPerValue); values=null; for (int j=0; j<vm; ++j) addValue(i.readDouble()); } /***/ public String toString(DicomDictionary dictionary) { StringBuffer str = new StringBuffer(); str.append(super.toString(dictionary)); str.append(" ["); try { double[] v = getDoubleValues(); if (v != null) { for (int j=0; j<v.length; ++j) { if (j > 0) str.append(","); str.append(v[j]); } } } catch (DicomException e) { str.append("XXXX"); } str.append("]"); return str.toString(); } /** * @param format the format to use for each numerical or decimal value * @exception DicomException */ public String[] getStringValues(NumberFormat format) throws DicomException { String sv[] = null; double[] v = getDoubleValues(); if (v != null) { sv=new String[v.length]; for (int j=0; j<v.length; ++j) { sv[j] = (format == null) ? FloatFormatter.toString(v[j]) : format.format(v[j]); } } return sv; } /** * @exception DicomException */ public double[] getDoubleValues() throws DicomException { return values; } /** * @param v * @exception DicomException */ public void addValue(double v) throws DicomException { flushCachedCopies(); values=ArrayCopyUtilities.expandArray(values); values[valueMultiplicity++]=v; valueLength+=8; } /** * @param v * @exception DicomException */ public void addValue(float v) throws DicomException { addValue((double)v); } /** * @param v * @exception DicomException */ public void addValue(short v) throws DicomException { addValue((double)v); } /** * @param v * @exception DicomException */ public void addValue(int v) throws DicomException { addValue((double)v); } /** * @param v * @exception DicomException */ public void addValue(long v) throws DicomException { addValue((double)v); } /** * @param v * @exception DicomException */ public void addValue(String v) throws DicomException { flushCachedCopies(); double doubleValue = 0; try { doubleValue=Double.parseDouble(v); } catch (NumberFormatException e) { throw new DicomException(e.toString()); } addValue(doubleValue); } /** * <p>Get the value representation of this attribute (FD).</p> * * @return 'F','D' in ASCII as a two byte array; see {@link com.pixelmed.dicom.ValueRepresentation ValueRepresentation} */ public byte[] getVR() { return ValueRepresentation.FD; } }