Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
## [7.0.0] - 2022-01-25
### Changed
- Package release version.

### Fixed
- Fixed null exception when importing files with masks. (Case 1388820)
  • Loading branch information
Unity Technologies committed Jan 25, 2022
1 parent 392315a commit 7e0f678
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 7 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
# Changelog

## [7.0.0] - 2022-01-25
### Changed
- Package release version.

### Fixed
- Fixed null exception when importing files with masks. (Case 1388820)

## [7.0.0-pre.4] - 2021-11-24
### Fixed
- Fixed per platform settings does not get applied in Windows platform. (Case 1376608)
Expand Down
36 changes: 35 additions & 1 deletion Editor/PSDPlugin/PsdFile/Layers/Mask.cs
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,11 @@ public Mask(Layer layer, Rectangle rect, byte color, BitVector32 flags)
/// </summary>
internal class MaskInfo
{
private static int s_UserMaskDensityBit = BitVector32.CreateMask();
private static int s_UserMaskFeatherBit = BitVector32.CreateMask(s_UserMaskDensityBit);
private static int s_VectorMaskDensityBit = BitVector32.CreateMask(s_UserMaskFeatherBit);
private static int s_VectorMaskFeatherBit = BitVector32.CreateMask(s_VectorMaskDensityBit);

public Mask LayerMask { get; set; }

public Mask UserMask { get; set; }
Expand All @@ -113,7 +118,7 @@ internal class MaskInfo
public MaskInfo()
{
}

public MaskInfo(PsdBinaryReader reader, Layer layer)
{
Util.DebugMessage(reader.BaseStream, "Load, Begin, MaskInfo");
Expand All @@ -139,6 +144,35 @@ public MaskInfo(PsdBinaryReader reader, Layer layer)
var userRectangle = reader.ReadRectangle();
UserMask = new Mask(layer, userRectangle, userBackgroundColor, new BitVector32(userFlagsByte));
}
else
{
// Only check if bit 4 is set. Testing shows there are discrepancy in file format documentation.
if (flagsByte == 16)
{
// Not using them so just read and discard the values
var maskParameters = new BitVector32(reader.ReadByte());
if (maskParameters[s_UserMaskDensityBit])
reader.ReadByte();

if (maskParameters[s_UserMaskFeatherBit])
reader.ReadDouble();

if (maskParameters[s_VectorMaskDensityBit])
reader.ReadByte();

if (maskParameters[s_VectorMaskFeatherBit])
reader.ReadDouble();
}

// The rest should be vector mask
if (reader.BaseStream.Position + 18 <= endPosition)
{
var userFlagsByte = reader.ReadByte();
var userBackgroundColor = reader.ReadByte();
var userRectangle = reader.ReadRectangle();
UserMask = new Mask(layer, userRectangle, userBackgroundColor, new BitVector32(userFlagsByte));
}
}

// 20-byte mask data will end with padding.
reader.BaseStream.Position = endPosition;
Expand Down
11 changes: 11 additions & 0 deletions Editor/PSDPlugin/PsdFile/PsdBinaryReader.cs
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,17 @@ public Int32 ReadInt32()
return val;
}

public double ReadDouble()
{
var val = reader.ReadDouble();
byte[] b = BitConverter.GetBytes(val);
{
Util.SwapBytes(b, 0, 8);
}
val = BitConverter.ToDouble(b, 0);
return val;
}

public Int64 ReadInt64()
{
var val = reader.ReadInt64();
Expand Down
12 changes: 6 additions & 6 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "com.unity.2d.psdimporter",
"version": "7.0.0-pre.4",
"version": "7.0.0",
"unity": "2022.1",
"displayName": "2D PSD Importer",
"description": "A ScriptedImporter for importing Adobe Photoshop PSB (Photoshop Big) file format. The ScriptedImporter is currently targeted for users who wants to create multi Sprite character animation using Unity 2D Animation Package.",
Expand All @@ -11,19 +11,19 @@
],
"category": "2D",
"dependencies": {
"com.unity.2d.animation": "8.0.0-pre.4",
"com.unity.2d.common": "7.0.0-pre.4",
"com.unity.2d.animation": "8.0.0",
"com.unity.2d.common": "7.0.0",
"com.unity.2d.sprite": "1.0.0"
},
"relatedPackages": {
"com.unity.2d.psdimporter.tests": "7.0.0-pre.4"
"com.unity.2d.psdimporter.tests": "7.0.0"
},
"upmCi": {
"footprint": "f1a15a8f988d611cbb180bebea038e1fe445bf5e"
"footprint": "5aba1aaa4a6f9d3fb3a1bcc61c4b2832cf317602"
},
"repository": {
"url": "https://github.cds.internal.unity3d.com/unity/2d.git",
"type": "git",
"revision": "2ccafc0d438881083c9c1ec71f92ef170494bd59"
"revision": "9b89f439ca5c8ef326594d90bc874e30e9e37104"
}
}

0 comments on commit 7e0f678

Please sign in to comment.