Aspose.PSD for Python via .NET 24.2 - 릴리스 노트
Contents
[
Hide
]
이 페이지에는 Aspose.PSD for Python via .NET 24.2의 릴리스 노트가 포함되어 있습니다.
키 | 요약 | 범주 |
---|---|---|
PSDPYTHON-28 | PatternFillSettings의 Angle 속성 처리 | 기능 |
PSDPYTHON-29 | TextLayer의 수직 및 수평 스케일 지원 | 기능 |
PSDPYTHON-33 | [AI 형식] PDF 기반 AI 형식에서 배경의 올바른 렌더링 구현 | 기능 |
PSDPYTHON-34 | 왜곡에서 Distort 메커니즘 변경 | 기능 향상 |
PSDPYTHON-35 | 왜곡 속도 향상 | 기능 향상 |
PSDPYTHON-36 | 문서를 열 때 “이미지 로드 실패” 예외 발생 | 버그 |
PSDPYTHON-37 | Stroke Pattern을 갖는 psd 파일 저장 수정 | 버그 |
PSDPYTHON-38 | ReplaceContents 사용 시 스마트 객체의 텍스트 스타일이 올바르지 않음 | 버그 |
PSDPYTHON-39 | [AI 형식] AI 파일에서 Cubic Bezier 렌더링 수정 | 버그 |
공개 API 변경
추가된 API:
- P:Aspose.PSD.FileFormats.Psd.Layers.LayerResources.PtFlResource.Angle
제거된 API:
- 없음
사용 예시:
사용 예시:
PSDPYTHON-28. PatternFillSettings의 Angle 속성 처리
fileName = "PatternFillLayerWide_0"
sourceFile = fileName + ".psd"
outputFile = fileName + "_output.psd"
loadOpt = PsdLoadOptions()
loadOpt.load_effects_resource = True
with PsdImage.load(sourceFile, loadOpt) as img:
image = cast(PsdImage, img)
fillLayer = cast(FillLayer, image.layers[1])
fillSettings = fillLayer.fill_settings
fillSettings.angle = 70
fillLayer.update()
image.save(outputFile, PsdOptions())
with PsdImage.load(outputFile, loadOpt) as img:
image = cast(PsdImage, img)
fillLayer = cast(FillLayer, image.layers[1])
fillSettings = fillLayer.fill_settings
assert fillSettings.angle == 70
PSDPYTHON-29. TextLayer의 수직 및 수평 스케일 지원
sourceFile = "1719_src.psd"
outputFile = "output.png"
# 몇 가지 글ꔼ 추가
fontsFolder = "1719_Fonts"
fontFolders = list(FontSettings.get_fonts_folders())
fontFolders.append(fontsFolder)
FontSettings.set_fonts_folders(fontFolders, True)
with PsdImage.load(sourceFile) as image:
image.save(outputFile, PngOptions())
PSDPYTHON-33. [AI 형식] PDF 기반 AI 형식에서 배경의 올바른 렌더링 구현
sourceFile = "pineapples.ai"
outputFile = "pineapples.png"
with AiImage.load(sourceFile) as image:
image.save(outputFile, PngOptions())
PSDPYTHON-34. 왜곡에서 Distort 메커니즘 변경
sourceFile = "crow_grid.psd"
outputFile = self.GetFileInOutputFolder("export.png")
opt = PsdLoadOptions()
opt.load_effects_resource = True
opt.allow_warp_repaint = True
pngOpt = PngOptions()
pngOpt.compression_level = 9
pngOpt.color_type = PngColorType.TRUECOLOR_WITH_ALPHA
with PsdImage.load(sourceFile, opt) as img:
img.save(outputFile, pngOpt)
PSDPYTHON-35. 왜곡 속도 향상
sourceFile = "output.psd"
outputFile = "export.png"
opt = PsdLoadOptions()
opt.load_effects_resource = True
opt.allow_warp_repaint = True
start_time = time.time()
pngOpt = PngOptions()
pngOpt.compression_level = 9
pngOpt.color_type = PngColorType.TRUECOLOR_WITH_ALPHA
with PsdImage.load(sourceFile, opt) as img:
img.save(outputFile, pngOpt)
elapsed_time = time.time() - start_time
# old value = 193300
# new value = 55500
time_in_sec = int(elapsed_time * 1000)
if time_in_sec > 100000:
raise Exception("Process time is too long")
PSDPYTHON-36. 문서를 열 때 “이미지 로드 실패” 예외 발생
sourceFile1 = "PRODUCT.ai"
outputFile1 = "PRODUCT.png"
with AiImage.load(sourceFile1) as image:
image.save(outputFile1, PngOptions())
sourceFile2 = "Dolota.ai"
outputFile2 = "Dolota.png"
with AiImage.load(sourceFile2) as image:
image.save(outputFile2, PngOptions())
sourceFile3 = "ARS_novelty_2108_out_01(1).ai"
outputFile3 = "ARS_novelty_2108_out_01(1).png"
with AiImage.load(sourceFile3) as image:
image.save(outputFile3, PngOptions())
sourceFile4 = "bit_gear.ai"
outputFile4 = "bit_gear.png"
with AiImage.load(sourceFile4) as image:
image.save(outputFile4, PngOptions())
sourceFile5 = "test.ai"
outputFile5 = "test.png"
with AiImage.load(sourceFile5) as image:
image.save(outputFile5, PngOptions())
PSDPYTHON-37. Stroke Pattern을 갖는 psd 파일 저장 수정
sourceFile = "StrokeShapePattern.psd"
outputFile = "StrokeShapePattern_output.psd"
newPatternBounds = Rectangle(0, 0, 4, 4)
guid = str(uuid.uuid4())
newPatternName = "$$$/Presets/Patterns/HorizontalLine1=Horizontal Line 9\0"
newPattern = [
Color.aqua.to_argb(), Color.red.to_argb(), Color.red.to_argb(), Color.aqua.to_argb(),
Color.aqua.to_argb(), Color.white.to_argb(), Color.white.to_argb(), Color.aqua.to_argb(),
Color.aqua.to_argb(), Color.white.to_argb(), Color.white.to_argb(), Color.aqua.to_argb(),
Color.aqua.to_argb(), Color.red.to_argb(), Color.red.to_argb(), Color.aqua.to_argb(),
]
with PsdImage.load(sourceFile) as img:
image = cast(PsdImage, img)
shapeLayer = cast(ShapeLayer, image.layers[1])
strokeInternalFillSettings = shapeLayer.fill
pattResource = None
for globalLayerResource in image.global_layer_resources:
pattResource = as_of(globalLayerResource, PattResource)
if pattResource is not None:
patternItem = pattResource.patterns[0] # 내부 패턴 데이터
patternItem.pattern_id = guid
patternItem.name = newPatternName
patternItem.set_pattern(newPattern, newPatternBounds)
break
strokeInternalFillSettings.pattern_name = newPatternName
strokeInternalFillSettings.pattern_id = guid + "\0"
shapeLayer.update()
image.save(outputFile)
# 변경된 데이터 확인.
with PsdImage.load(outputFile) as img:
image = cast(PsdImage, img)
shapeLayer = cast(ShapeLayer, image.layers[1])
strokeInternalFillSettings = shapeLayer.fill
assert guid.upper() == strokeInternalFillSettings.pattern_id
assert newPatternName == strokeInternalFillSettings.pattern_name + "\0"
PSDPYTHON-38. ReplaceContents 사용 시 스마트 객체의 텍스트 스타일이 올바르지 않음
inputFile = "source.psd"
output2 = "output.png"
psdLoadOptions = PsdLoadOptions()
psdLoadOptions.load_effects_resource = True
with PsdImage.load(inputFile, psdLoadOptions) as image:
psdImage = cast(PsdImage, image)
smartObject = cast(SmartObjectLayer, psdImage.layers[1])
smartObjectImage = cast(PsdImage, smartObject.load_contents(psdLoadOptions))
with smartObjectImage:
smartObject.replace_contents(smartObjectImage)
pngOpt = PngOptions()
pngOpt.color_type = PngColorType.TRUECOLOR_WITH_ALPHA
psdImage.save(output2, pngOpt)
PSDPYTHON-39. [AI 형식] AI 파일에서 Cubic Bezier 렌더링 수정
sourceFile = "Typography.ai"
outputFilePath = "Typography.png"
with AiImage.load(sourceFile) as image:
image.save(outputFilePath, PngOptions())