Mercurial > projects > dwt-win
view dwt/internal/image/JPEGScanHeader.d @ 213:36f5cb12e1a2
Update to SWT 3.4M7
author | Frank Benoit <benoit@tionex.de> |
---|---|
date | Sat, 17 May 2008 17:34:28 +0200 |
parents | 9a64a7781bab |
children |
line wrap: on
line source
/******************************************************************************* * Copyright (c) 2000, 2005 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * IBM Corporation - initial API and implementation * Port to the D programming language: * Frank Benoit <benoit@tionex.de> *******************************************************************************/ module dwt.internal.image.JPEGScanHeader; import dwt.DWT; import dwt.internal.image.JPEGVariableSizeSegment; import dwt.internal.image.LEDataInputStream; import dwt.internal.image.JPEGFileFormat; import dwt.dwthelper.utils; final class JPEGScanHeader : JPEGVariableSizeSegment { public int[][] componentParameters; public this(byte[] reference) { super(reference); } public this(LEDataInputStream byteStream) { super(byteStream); initializeComponentParameters(); } public int getApproxBitPositionHigh() { return reference[(2 * getNumberOfImageComponents()) + 7] >> 4; } public int getApproxBitPositionLow() { return reference[(2 * getNumberOfImageComponents()) + 7] & 0xF; } public int getEndOfSpectralSelection() { return reference[(2 * getNumberOfImageComponents()) + 6]; } public int getNumberOfImageComponents() { return reference[4]; } public int getStartOfSpectralSelection() { return reference[(2 * getNumberOfImageComponents()) + 5]; } /* Used when decoding. */ void initializeComponentParameters() { int compCount = getNumberOfImageComponents(); componentParameters = null; for (int i = 0; i < compCount; i++) { int ofs = 5 + i * 2; int cid = reference[ofs] & 0xFF; int dc = (reference[ofs + 1] & 0xFF) >> 4; int ac = reference[ofs + 1] & 0xF; if (componentParameters.length <= cid) { int[][] newParams = new int[][](cid + 1); System.arraycopy(componentParameters, 0, newParams, 0, componentParameters.length); componentParameters = newParams; } componentParameters[cid] = [ dc, ac ]; } } /* Used when encoding. */ public void initializeContents() { int compCount = getNumberOfImageComponents(); int[][] compSpecParams = componentParameters; if (compCount is 0 || compCount !is compSpecParams.length) { DWT.error(DWT.ERROR_INVALID_IMAGE); } for (int i = 0; i < compCount; i++) { int ofs = i * 2 + 5; int[] compParams = compSpecParams[i]; reference[ofs] = cast(byte)(i + 1); reference[ofs + 1] = cast(byte)(compParams[0] * 16 + compParams[1]); } } public void setEndOfSpectralSelection(int anInteger) { reference[(2 * getNumberOfImageComponents()) + 6] = cast(byte)anInteger; } public void setNumberOfImageComponents(int anInteger) { reference[4] = cast(byte)(anInteger & 0xFF); } public void setStartOfSpectralSelection(int anInteger) { reference[(2 * getNumberOfImageComponents()) + 5] = cast(byte)anInteger; } public override int signature() { return JPEGFileFormat.SOS; } public bool verifyProgressiveScan() { int start = getStartOfSpectralSelection(); int end = getEndOfSpectralSelection(); int low = getApproxBitPositionLow(); int high = getApproxBitPositionHigh(); int count = getNumberOfImageComponents(); if ((start is 0 && end is 00) || (start <= end && end <= 63)) { if (low <= 13 && high <= 13 && (high is 0 || high is low + 1)) { return start is 0 || (start > 0 && count is 1); } } return false; } public bool isACProgressiveScan() { return getStartOfSpectralSelection() !is 0 && getEndOfSpectralSelection() !is 0; } public bool isDCProgressiveScan() { return getStartOfSpectralSelection() is 0 && getEndOfSpectralSelection() is 0; } public bool isFirstScan() { return getApproxBitPositionHigh() is 0; } }