-
Notifications
You must be signed in to change notification settings - Fork 193
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Imaging-162 #11
Open
mgmechanics
wants to merge
24
commits into
apache:trunk
Choose a base branch
from
mgmechanics:IMAGING-162
base: trunk
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Imaging-162 #11
Changes from 21 commits
Commits
Show all changes
24 commits
Select commit
Hold shift + click to select a range
16b8d35
Added example for bitmap with negative height
mgmechanics e780954
moved info to info.txt
mgmechanics ba340c5
moved image file to get it out of automatic use in existing tests bec…
mgmechanics ac98229
added tests to reproduce IMAGING-162
mgmechanics 609fc9c
image info is correct even for bitmaps with negative height - one tes…
mgmechanics 6152899
added exception in case of someone tries to read an image with negati…
mgmechanics b3e79ad
typo
mgmechanics 4a787b4
corrected use of wrong kind of height
mgmechanics ad478a9
further distinct between raw and absolute height
mgmechanics 89d0d7f
added test which should return OK once reading bitmaps with negative …
mgmechanics c956572
reverted recent changes in sources but not in tests
mgmechanics e7c8d7d
implemented better solution
mgmechanics 49633f0
renamed test class
mgmechanics a59e7d8
added correct colors and two methods to print the colors of the image
mgmechanics fa263a2
added test for bmp image with positive height
mgmechanics 1e735e3
added test to image info for bmp image with positive height
mgmechanics aece262
added info from bitmap header info to debug output
mgmechanics 7dbded4
doc
mgmechanics 70f24db
fixed IMAGING-162 for non-RLE-encoded bitmaps
mgmechanics 56f98b7
checked that my fix IMAGING-162 doesn't break anything for RLE-compre…
mgmechanics 5610b5f
moved common methods to utility class
mgmechanics 29b585c
doc
mgmechanics dd08b0c
found much simpler solution - restored ImageBuilder to trunk
mgmechanics 5472f19
removed wrong comment
mgmechanics File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,8 @@ | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
* Changed 2015 by Michael Gross, [email protected] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can not be applied with this change. |
||
*/ | ||
package org.apache.commons.imaging.formats.bmp; | ||
|
||
|
@@ -33,6 +35,12 @@ class BmpHeaderInfo { | |
public final int bitmapHeaderSize; | ||
public final int width; | ||
public final int height; | ||
/** | ||
* According to specification the height can be negative. | ||
* <br>Positive height: Bitmap is stored bottom-up (0, 0 is in the bottom left corner), then this field is true | ||
* <br>Negative height: Bitmap is stored top-down (0, 0 is in the top left corner), then this field is false | ||
*/ | ||
public final boolean isBottomUpBitmap; | ||
public final int planes; | ||
public final int bitsPerPixel; | ||
public final int compression; | ||
|
@@ -85,7 +93,8 @@ public BmpHeaderInfo(final byte identifier1, final byte identifier2, final int f | |
|
||
this.bitmapHeaderSize = bitmapHeaderSize; | ||
this.width = width; | ||
this.height = height; | ||
this.height = (height >= 0) ? height : height * -1; | ||
this.isBottomUpBitmap = height >= 0; | ||
this.planes = planes; | ||
this.bitsPerPixel = bitsPerPixel; | ||
this.compression = compression; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,8 @@ | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
* Changed 2015 by Michael Gross, [email protected] | ||
*/ | ||
package org.apache.commons.imaging.formats.bmp; | ||
|
||
|
@@ -401,6 +403,7 @@ private ImageContents readImageContents(final InputStream is, | |
// this.debugNumber("ExtraBitsPerPixel", ExtraBitsPerPixel, 4); | ||
debugNumber("bhi.Width", bhi.width, 4); | ||
debugNumber("bhi.Height", bhi.height, 4); | ||
debugNumber("bhi.isBottomUpBitmap: " + bhi.isBottomUpBitmap, 0, 0); | ||
debugNumber("ImageLineLength", imageLineLength, 4); | ||
// this.debugNumber("imageDataSize", imageDataSize, 4); | ||
debugNumber("PixelCount", pixelCount, 4); | ||
|
@@ -714,10 +717,11 @@ public BufferedImage getBufferedImage(final InputStream inputStream, Map<String, | |
System.out.println("height: " + height); | ||
System.out.println("width*height: " + width * height); | ||
System.out.println("width*height*4: " + width * height * 4); | ||
System.out.println("image data are stored bottom-up (true) or top-down (false): " + bhi.isBottomUpBitmap); | ||
} | ||
|
||
final PixelParser pixelParser = ic.pixelParser; | ||
final ImageBuilder imageBuilder = new ImageBuilder(width, height, true); | ||
final ImageBuilder imageBuilder = new ImageBuilder(bhi.isBottomUpBitmap, width, height, true); | ||
pixelParser.processImage(imageBuilder); | ||
|
||
return imageBuilder.getBufferedImage(); | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,8 @@ | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
* Changed 2015 by Michael Gross, [email protected] | ||
*/ | ||
package org.apache.commons.imaging.formats.bmp; | ||
|
||
|
@@ -32,14 +34,29 @@ public PixelParserSimple(final BmpHeaderInfo bhi, final byte[] colorTable, final | |
|
||
@Override | ||
public void processImage(final ImageBuilder imageBuilder) throws ImageReadException, IOException { | ||
for (int y = bhi.height - 1; y >= 0; y--) { | ||
for (int x = 0; x < bhi.width; x++) { | ||
final int rgb = getNextRGB(); | ||
// image data are stored bottom-up | ||
if (imageBuilder.readBottomUp() == true) { | ||
for (int y = bhi.height - 1; y >= 0; y--) { | ||
for (int x = 0; x < bhi.width; x++) { | ||
final int rgb = getNextRGB(); | ||
|
||
imageBuilder.setRGB(x, y, rgb); | ||
// db.setElem(y * bhi.width + x, rgb); | ||
} | ||
newline(); | ||
} | ||
} | ||
// image data are stored top-down | ||
else { | ||
for (int y = 0; y < bhi.height; y++) { | ||
for (int x = 0; x < bhi.width; x++) { | ||
final int rgb = getNextRGB(); | ||
|
||
imageBuilder.setRGB(x, y, rgb); | ||
// db.setElem(y * bhi.width + x, rgb); | ||
imageBuilder.setRGB(x, y, rgb); | ||
// db.setElem(y * bhi.width + x, rgb); | ||
} | ||
newline(); | ||
} | ||
newline(); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,8 +13,14 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
|
||
Changed 2015 by Michael Gross, [email protected] | ||
|
||
|
||
Adding any image file to this folder means that this file will used immediately | ||
in various tests. These tests use certain functions of this library for all | ||
image files in this folder. | ||
For example, consider an bmp image file which shall bring up an exception. | ||
Adding this file here will cause some existing tests to fail while the same tests | ||
pass for all other bmp images in this folder. | ||
|
||
|
||
bmp/1/Oregon Scientific DS6639 - DSC_0307 - small.bmp | ||
|
@@ -37,7 +43,7 @@ bmp/4/rle4deltaXY.asm | |
bmp/4/rle4deltaXY.bmp | ||
Contributed by Damjan Jovanovic. | ||
4 bit RLE compression with an encoded-mode delta-Y | ||
|
||
dcx/1/Oregon Scientific DS6639 - DSC_0307 - small.dcx | ||
Charles Matthew Chen's reference photo, converted by Damjan Jovanovic. | ||
|
||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file added
BIN
+21.6 KB
src/test/data/specificTests/bmp/1/monochrome-positive-height_TheGimpOptions.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Binary file added
BIN
+21.8 KB
...test/data/specificTests/bmp/2/monochrome-positive-height-rle_TheGimpOptions.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
Licensed to the Apache Software Foundation (ASF) under one or more | ||
contributor license agreements. See the NOTICE file distributed with | ||
this work for additional information regarding copyright ownership. | ||
The ASF licenses this file to You under the Apache License, Version 2.0 | ||
(the "License"); you may not use this file except in compliance with | ||
the License. You may obtain a copy of the License at | ||
|
||
http://www.apache.org/licenses/LICENSE-2.0 | ||
|
||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
|
||
Added 2015 by Michael Gross, [email protected] | ||
|
||
Adding a file to this folder has no effect to any existing test. If you want to | ||
use a just added file you need to add test which uses this file. | ||
|
||
For example, this folder can be used to keep images which cause an exception. | ||
|
||
bmp/1/monochrome-negative-height.bmp | ||
Monochrome 4x8 bitmap with negative height value. | ||
This image was taken from http://issues.apache.org/jira/browse/IMAGING-162. | ||
It was attached there by Myroslav Golub. | ||
|
||
bmp/1/monochrome-positive-height.bmp | ||
Monochrome 4x8 bitmap with positive height value. | ||
monochrome-positive-height.xfc is the original file created with "The Gimp 2.8.10". | ||
monochrome-positive-height.bmp itself was created by exporting the xfc image to bmp | ||
using the options shown in monochrome-positive-height_TheGimpOptions.png. | ||
|
||
bmp/2/monochrome-positive-height-rle.bmp | ||
Monochrome 4x8 bitmap with positive height value. | ||
monochrome-positive-height-rle.xfc is the original file created with "The Gimp 2.8.10". | ||
monochrome-positive-height-rle.bmp itself was created by exporting the xfc image to bmp | ||
using the options shown in monochrome-positive-height-rle_TheGimpOptions.png. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,8 @@ | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
* Changed 2015 by Michael Gross, [email protected] | ||
*/ | ||
|
||
package org.apache.commons.imaging; | ||
|
@@ -24,13 +26,13 @@ | |
public interface ImagingTestConstants { | ||
|
||
static final File PHIL_HARVEY_TEST_IMAGE_FOLDER = new File( | ||
FilenameUtils | ||
.separatorsToSystem("src\\test\\data\\images\\exif\\philHarvey\\")); | ||
FilenameUtils.separatorsToSystem("src\\test\\data\\images\\exif\\philHarvey\\") | ||
); | ||
|
||
static final File SOURCE_FOLDER = new File("src"); | ||
static final File TEST_SOURCE_FOLDER = new File(SOURCE_FOLDER, "test"); | ||
static final File TEST_DATA_SOURCE_FOLDER = new File(TEST_SOURCE_FOLDER, | ||
"data"); | ||
static final File TEST_IMAGE_FOLDER = new File(TEST_DATA_SOURCE_FOLDER, | ||
"images"); | ||
static final File TEST_DATA_SOURCE_FOLDER = new File(TEST_SOURCE_FOLDER, "data"); | ||
static final File TEST_IMAGE_FOLDER = new File(TEST_DATA_SOURCE_FOLDER, "images"); | ||
// folder for files fo specific tests, see info.txt in the named folder | ||
static final File TEST_SPECIFIC_FOLDER = new File(TEST_DATA_SOURCE_FOLDER, "specificTests"); | ||
} |
101 changes: 101 additions & 0 deletions
101
src/test/java/org/apache/commons/imaging/formats/bmp/specific/BmpReadHeightRleTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
/* | ||
* Licensed to the Apache Software Foundation (ASF) under one or more | ||
* contributor license agreements. See the NOTICE file distributed with | ||
* this work for additional information regarding copyright ownership. | ||
* The ASF licenses this file to You under the Apache License, Version 2.0 | ||
* (the "License"); you may not use this file except in compliance with | ||
* the License. You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
* Added 2015 by Michael Gross, [email protected] | ||
* Changed 2015 by Michael Gross, [email protected] | ||
*/ | ||
|
||
package org.apache.commons.imaging.formats.bmp.specific; | ||
|
||
import org.apache.commons.imaging.formats.bmp.*; | ||
import static org.junit.Assert.assertNotNull; | ||
import static org.junit.Assert.assertEquals; | ||
|
||
import java.awt.image.BufferedImage; | ||
import java.io.File; | ||
import java.io.IOException; | ||
import java.util.HashMap; | ||
import java.util.Map; | ||
|
||
import org.apache.commons.imaging.ImageInfo; | ||
import org.apache.commons.imaging.ImageReadException; | ||
import org.apache.commons.imaging.Imaging; | ||
import org.apache.commons.imaging.ImagingConstants; | ||
import org.apache.commons.imaging.test.util.BufferedImageTools; | ||
import org.junit.Test; | ||
|
||
/** | ||
* This test class contains tests specific for reading an image with | ||
* negative and positive height. | ||
* These are tests for image files where the image data are RLE-compressed. | ||
*/ | ||
public class BmpReadHeightRleTest extends BmpBaseTest { | ||
/** | ||
* Get image info for a bmp with positive height. | ||
* Expected result: All information about the size of the image are positive numbers. | ||
* @throws ImageReadException | ||
* @throws IOException | ||
*/ | ||
@Test | ||
public void testImageInfoPositiveHeight() throws ImageReadException, IOException { | ||
// set to true to print image data to STDOUT | ||
final boolean debugMode = false; | ||
final File imageFile = new File(TEST_SPECIFIC_FOLDER, "bmp/2/monochrome-positive-height-rle.bmp"); | ||
final Map<String, Object> params = new HashMap<String, Object>(); | ||
if (debugMode) params.put(ImagingConstants.PARAM_KEY_VERBOSE, true); | ||
final ImageInfo imageInfo = Imaging.getImageInfo(imageFile, params); | ||
|
||
assertNotNull(imageInfo); | ||
assertEquals(8, imageInfo.getHeight()); | ||
assertEquals(72, imageInfo.getPhysicalHeightDpi()); | ||
assertEquals(0.11111111f, imageInfo.getPhysicalHeightInch(), 0.1f); | ||
} | ||
|
||
/** | ||
* Get a buffered image for a bmp with positive height. | ||
* Expected: The test image has white pixels in each corner except bottom left (there is a black one). | ||
* This test is to prove that changes to enable reading bmp images with negative height doesn't break | ||
* the ability to read bmp images with positive height. | ||
* @throws ImageReadException | ||
* @throws IOException | ||
*/ | ||
@Test | ||
public void testBufferedImagePositiveHeight() throws Exception { | ||
// set to true to print image data to STDOUT | ||
final boolean debugMode = false; | ||
final File imageFile = new File(TEST_SPECIFIC_FOLDER, "bmp/2/monochrome-positive-height-rle.bmp"); | ||
final BufferedImage bufImage = Imaging.getBufferedImage(imageFile); | ||
|
||
if (debugMode) BufferedImageTools.debugBufferedImageAsTable(bufImage, "positive height rle"); | ||
assertEquals(8, bufImage.getHeight()); | ||
assertEquals(4, bufImage.getWidth()); | ||
// the image is monochrome and has 4 black pixels, the remaning pixel are white | ||
// the black pixels a placed such that we can make sure the picture is read as expected | ||
// -16777216 => -2^24 => black (4 pixels); -1 => white (other pixels) | ||
// top left - white | ||
assertEquals(-1, bufImage.getRGB(0, 0)); | ||
// top right - white | ||
assertEquals(-1, bufImage.getRGB(3, 0)); | ||
// bottom left - black | ||
assertEquals(-16777216, bufImage.getRGB(0, 7)); | ||
// bottom right - white | ||
assertEquals(-1, bufImage.getRGB(3, 7)); | ||
//other black pixels - just for fun | ||
assertEquals(-16777216, bufImage.getRGB(1, 6)); | ||
assertEquals(-16777216, bufImage.getRGB(2, 5)); | ||
assertEquals(-16777216, bufImage.getRGB(3, 4)); | ||
} | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a way for us to detect whether the image is bottom up?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Michael Groß