Aspose.PSD for .NET 23.7 - 릴리스 노트
Contents
[
Hide
]
이 페이지에는 Aspose.PSD for .NET 23.7의 릴리스 노트가 포함되어 있습니다.
키 | 요약 | 카테고리 |
---|---|---|
PSDNET-802 | PSD 파일의 각 레이어를 애니메이션 GIF 파일로 내보내는 기능 추가 | 기능 |
PSDNET-1441 | Shape 레이어의 채우기 속성을 vscg 리소스의 형태로 할당 | 기능 |
PSDNET-1534 | 새로운 와프 유형 추가 (arc 및 arch) | 기능 |
PSDNET-1543 | PSD 파일을 저장하는 응용 프로그램을 변경하여 속성 UpdateMetadata가 true로 설정된 경우 Aspose.PSD로 변경 | 기능 |
PSDNET-1567 | 와프 이미지의 계산 영역 증가 | 기능 |
PSDNET-1471 | 흑백 조정 레이어가 반투명을 잘못 처리함 | 버그 |
PSDNET-1505 | SmartObject ReplaceContents(AllowWarpRepaint 옵션이 활성화된 경우) 계산 후 2분 후에 실패 | 버그 |
PSDNET-1585 | 실제 LayerGroup 좌측 및 상단 위치 가져오는 기능 추가 | 버그 |
PSDNET-1589 | 레이어 크기 조정이 VogkResource와 함께 구조를 포인트 단위로 갖는 psd 파일에서 잘못 작동함 | 버그 |
PSDNET-1608 | TextBound가 예상대로 작동하지 않음 | 버그 |
PSDNET-1612 | 기본 생성자로 생성된 레이어를 PSD 이미지에 추가하면 기본 리소스가 추가되지 않음 | 버그 |
PSDNET-1623 | Animated GIF로 내보낼 때 Timeline.LoopesCount가 무시됨 | 버그 |
Public API 변경
추가된 API:
- P:Aspose.PSD.ImageOptions.PsdOptions.UpdateMetadata
- F:Aspose.PSD.FileFormats.Ai.AiFormatVersion.Pdf16
- F:Aspose.PSD.FileFormats.Ai.AiFormatVersion.Pdf17
- P:Aspose.PSD.Xmp.Schemas.XmpBaseSchema.XmpBasicPackage.Item(System.String)
- M:Aspose.PSD.Xmp.Schemas.XmpBaseSchema.XmpBasicPackage.SetValue(System.String,Aspose.PSD.Xmp.IXmlValue)
- M:Aspose.PSD.Xmp.Schemas.XmpBaseSchema.XmpBasicPackage.ContainsKey(System.String)
- P:Aspose.PSD.FileFormats.Psd.Layers.ShapeLayer.Fill
제거된 API:
- P:Aspose.PSD.FileFormats.Psd.Layers.LayerResources.VectorPath.FillColor
사용 예시:
PSDNET-802. PSD 파일의 각 레이어를 애니메이션 GIF 파일로 내보내는 기능 추가
string src = "EachLayerIsFrame.psd";
string outputGif = "out_EachLayerIsFrame.gif";
string outputPsd = "out_EachLayerIsFrame.psd";
using (var psdImage = (PsdImage)Image.Load(src))
{
// 각 레이어에 대한 프레임 생성.
int framesCount = psdImage.Layers.Length;
var timeline = psdImage.Timeline;
Frame[] frames = new Frame[framesCount];
for (int i = 0; i < framesCount; i++)
{
frames[i] = new Frame();
LayerState[] layerStates = new LayerState[framesCount];
for (int j = 0; j < framesCount; j++)
{
layerStates[j] = new LayerState();
layerStates[j].Enabled = i == j;
}
frames[i].LayerStates = layerStates;
}
timeline.Frames = frames;
// 현재 상태 업데이트
Layer[] layers = psdImage.Layers;
LayerState[] states = timeline.Frames[timeline.ActiveFrameIndex].LayerStates;
for (int i = 0; i < framesCount; i++)
{
layers[i].IsVisible = states[i].Enabled;
}
timeline.Save(outputGif, new GifOptions());
psdImage.Save(outputPsd);
}
PSDNET-1441. Shape 레이어의 채우기 속성을 vscg 리소스의 형태로 할당
string srcFile = "ShapeInternalSolid.psd";
string outFile = "ShapeInternalSolid.psd.out.psd";
using (PsdImage image = (PsdImage)Image.Load(
srcFile,
new PsdLoadOptions { LoadEffectsResource = true }))
{
ShapeLayer shapeLayer = (ShapeLayer)image.Layers[1];
ColorFillSettings fillSettings = (ColorFillSettings)shapeLayer.Fill;
fillSettings.Color = Color.Red;
shapeLayer.Update();
image.Save(outFile);
}
// 변경된 내용 확인
using (PsdImage image = (PsdImage)Image.Load(
outFile,
new PsdLoadOptions { LoadEffectsResource = true }))
{
ShapeLayer shapeLayer = (ShapeLayer)image.Layers[1];
ColorFillSettings fillSettings = (ColorFillSettings)shapeLayer.Fill;
AssertAreEqual(Color.Red, fillSettings.Color);
image.Save(outFile);
}
void AssertAreEqual(object expected, object actual, string message = null)
{
if (!object.Equals(expected, actual))
{
throw new Exception(message ?? "객체가 같지 않습니다.");
}
}
PSDNET-1471. 흑백 조정 레이어가 반투명을 잘못 처리함
string srcFile = "frog_nosymb.psd";
string outFile = "frog_nosymb.psd.out.psd";
using (PsdImage psdImage = (PsdImage)Image.Load(srcFile))
{
psdImage.AddBlackWhiteAdjustmentLayer();
psdImage.Save(outFile);
}
// 변경된 내용 확인
using (PsdImage image = (PsdImage)Image.Load(
outFile,
new PsdLoadOptions { LoadEffectsResource = true }))
{
AssertAreEqual(2, image.Layers.Length);
BlackWhiteAdjustmentLayer blackWhiteAdjustmentLayer = (BlackWhiteAdjustmentLayer)image.Layers[1];
if (blackWhiteAdjustmentLayer == null)
{
throw new Exception("레이어 2는 BlackWhiteAdjustmentLayer여야 함");
}
image.Save(outFile);
}
void AssertAreEqual(object expected, object actual, string message = null)
{
if (!object.Equals(expected, actual))
{
throw new Exception(message ?? "객체가 같지 않습니다.");
}
}
PSDNET-1505. SmartObject ReplaceContents (AllowWarpRepaint 옵션이 활성화된 경우) 2분 이상 계산 후 실패
string sourceFile = "mug 4.psd";
string changeFile = "artwork for replace.png";
string outputFile = "export.png";
int newHeight = 300;
using (var psdImage = (PsdImage)Image.Load(sourceFile, new PsdLoadOptions() { AllowWarpRepaint = true, LoadEffectsResource = true }))
{
SmartObjectLayer smartObjectLayer = (SmartObjectLayer)psdImage.Layers[3];
var scale = (double)newHeight / smartObjectLayer.Height;
var newWidth = (int)Math.Round(smartObjectLayer.Width * scale);
PsdImage innerImage = new PsdImage(newWidth, newHeight);
innerImage.SetResolution(72, 72);
Stream innerStream = new FileStream(changeFile, FileMode.Open);
Layer layer = new Layer(innerStream) { HorizontalResolution = 72, VerticalResolution = 72 };
try
{
innerImage.AddLayer(layer);
smartObjectLayer.ReplaceContents(innerImage);
smartObjectLayer.UpdateModifiedContent();
psdImage.Save(outputFile, new PngOptions
{
ColorType = PngColorType.TruecolorWithAlpha
});
}
finally
{
innerImage.Dispose();
innerStream.Dispose();
layer.Dispose();
}
}
PSDNET-1534. 새로운 와프 유형 추가 (arc 및 arch)
string sourceArcFile = "arc_warp.psd";
string outputArcFile = "arc_export.png";
string sourceArchFile = "arch_warp.psd";
string outputArchFile = "arch_export.png";
using (var psdImage = (PsdImage)Image.Load(sourceArcFile, new PsdLoadOptions() { AllowWarpRepaint = true, LoadEffectsResource = true }))
{
psdImage.Save(outputArcFile, new PngOptions
{
ColorType = PngColorType.TruecolorWithAlpha
});
}
using (var psdImage = (PsdImage)Image.Load(sourceArchFile, new PsdLoadOptions() { AllowWarpRepaint = true, LoadEffectsResource = true }))
{
psdImage.Save(outputArchFile, new PngOptions
{
ColorType = PngColorType.TruecolorWithAlpha
});
}
PSDNET-1543. 속성 UpdateMetadata가 true로 설정된 경우 PSD 파일을 저장하는 응용 프로그램을 Aspose.PSD로 변경
string path = "output.psd";
using (var image = new PsdImage(100, 100))
{
// 만약 작성 도구를 변경하고 싶다면 "UpdateMetadata" 속성이 true로 설정되어 있는지 확인하십시오. 기본적으로 true로 설정됩니다.
var psdOptions = new PsdOptions();
psdOptions.UpdateMetadata = true;
// 이미지 저장.
image.Save(path, psdOptions);
// 코드에서 작성 도구 확인.
var xmpData = image.XmpData;
var basicPackage = image.XmpData.GetPackage(Namespaces.XmpBasic);
// 여기에 업데이트된 작성 도구 정보가 있습니다.
var currentCreatorTool = (string)basicPackage[":CreatorTool"];
}
PSDNET-1567. 와프 이미지의 계산 영역 증가
string sourceFile = "mug4_warp.psd";
string outputFile = "mug4_export.png";
using (var psdImage = (PsdImage)Image.Load(sourceFile, new PsdLoadOptions() { AllowWarpRepaint = true, LoadEffectsResource = true }))
{
psdImage.Save(outputFile, new PngOptions
{
ColorType = PngColorType.TruecolorWithAlpha
});
}
PSDNET-1585. 실제 LayerGroup 좌측 및 상단 위치 가져오는 기능 추가
string sourceFile = "layerGroupFigures.psd";
void AssertAreEqual(object expected, object actual)
{
if (!object.Equals(expected, actual))
{
throw new Exception("객체가 같지 않습니다.");
}
}
using (var image = (PsdImage)Image.Load(sourceFile))
{
var layers = image.Layers;
for (int i = 0; i < layers.Length; i++)
{
var layer = layers[i];
if (layer is LayerGroup)
{
// LayerGroup 가져오기.
var group = (LayerGroup)layer;
var expectedLeft = int.MaxValue;
var expectedTop = int.MaxValue;
var expectedRight = 0;
var expectedBottom = 0;
// 실제 좌측, 상단, 우측 및 하단 위치 계산.
foreach (var innerLayer in group.Layers)
{
if (innerLayer is AdjustmentLayer || innerLayer.Bounds.IsEmpty)
{
continue;
}
expectedLeft = Math.Min(expectedLeft, innerLayer.Left);
expectedTop = Math.Min(expectedTop, innerLayer.Top);
expectedRight = Math.Max((expectedLeft + group.Width), (innerLayer.Left + innerLayer.Width));
expectedBottom = Math.Max((expectedTop + group.Height), (innerLayer.Top + innerLayer.Height));
}
// LayerGroup 좌측, 상단, 우측 및 하단 위치가 올바르게 계산됨.
AssertAreEqual(group.Left, expectedLeft);
AssertAreEqual(group.Top, expectedTop);
AssertAreEqual(group.Right, expectedRight);
AssertAreEqual(group.Bottom, expectedBottom);
}
}
}
PSDNET-1589. VogkResource에 구조체가 포인트로 있는 psd 파일의 레이어 크기 조정이 잘못 작동함
string[] sourceFiles = new string[]
{
"PointsVectorOrigin.psd",
"TopVogkResStruct.psd"
};
foreach (string sourceFile in sourceFiles)
{
using (PsdImage image = (PsdImage)Image.Load(sourceFile))
{
Layer layer = image.Layers[0];
layer.Resize(50, 50);
AssertAreEqual(layer.Height, 50);
AssertAreEqual(layer.Width, 50);
}
}
void AssertAreEqual(object expected, object actual, string message = null)
{
if (!object.Equals(expected, actual))
{
throw new Exception(message ?? "객체가 같지 않습니다.");
}
}
PSDNET-1608. TextBound가 예상대로 작동하지 않음
string sourceFile = "input_Test_forTicket.psd";
string outFile = "out_1608.psd";
Size newTextBox = new Size(-1, -1);
using (PsdImage psdImage = (PsdImage)Aspose.PSD.Image.Load(sourceFile))
{
//단계: 텍스트 교체
TextLayer textLayer = (TextLayer)psdImage.Layers[3];
textLayer.TextData.Items[0].Text = "텍스트 테스트 대체됨";
//Step: TextBoundBox 업데이트
textLayer.TextData.UpdateLayerData();
newTextBox = new Size((int)Math.Ceiling(textLayer.TextBoundBox.Width), textLayer.Height);
textLayer.TextBoundBox = new Aspose.PSD.RectangleF(PointF.Empty, newTextBox);
textLayer.TextData.UpdateLayerData();
psdImage.Save(outFile);
}
// 변경 사항 확인
using (var psdImage = (PsdImage)Image.Load(outFile))
{
Txt2Resource txt2Resource = (Txt2Resource)psdImage.GlobalLayerResources[1];
string textData = Encoding.GetEncoding("Windows-1251").GetString(txt2Resource.Data);
string search = "<< /0 << /1 << /0 ["; //이 파일에서 textBox 값을 찾기 위한 특정 문자열
int startIndex = textData.IndexOf(search) + search.Length;
int endIndex = textData.IndexOf("]", startIndex);
string boxItems = textData.Substring(startIndex, endIndex - startIndex);
string height = newTextBox.Height.ToString("0.0####").Replace(",", ".");
string width = newTextBox.Width.ToString("0.0####").Replace(",", ".");
if (!boxItems.Contains(height) || !boxItems.Contains(width))
{
throw new Exception("TextBox가 업데이트되지 않았습니다.");
}
}
PSDNET-1612. 기본 생성자로 생성된 레이어를 PSD 이미지에 추가하면 기본 리소스가 추가되지 않음
string output = "newLayer.psd";
using (var psdImage = new PsdImage(500, 500))
{
var layer = new Layer();
psdImage.AddLayer(layer);
LyidResource lyidResource = (LyidResource)FindResource(LyidResource.TypeToolKey, layer.Resources);
int layerId = lyidResource.Value; // NullReferenceException 발생
psdImage.Save(output);
}
LayerResource FindResource(int resType, LayerResource[] resources)
{
if (resources != null)
{
foreach (var layerResource in resources)
{
if (layerResource.Key == resType)
{
return layerResource;
}
}
}
return null;
}
PSDNET-1623. Animated GIF로 내보낼 때 Timeline.LoopesCount가 무시됨
string sourceFile = "4_animated.psd";
string outputGif = "out_4_animated.psd.gif";
using (var psdImage = (PsdImage)Image.Load(sourceFile, new PsdLoadOptions() { LoadEffectsResource = true }))
{
psdImage.Timeline.Save(outputGif, new