@wmakeev/darkroom-xmp-tools
v2.0.4
Published
Retrieve and update darkroom operations params stored in sidecar xmp files
Maintainers
Readme
darkroom-xmp-tools
Retrieve and update darktable operations params stored in sidecar xmp files. This helps automate image processing with darktable-cli
Install
Tested on: MacOS and Linux
$ npm install @wmakeev/darkroom-xmp-tools
Usage
Take some darktable XMP
...
<darktable:history>
<rdf:Seq>
...
<rdf:li
darktable:operation="exposure"
darktable:enabled="1"
darktable:modversion="5"
darktable:params="0000000040a0093bd8ce374000004842000080c0"
darktable:multi_name="1"
darktable:multi_priority="0"
darktable:blendop_version="7"
darktable:blendop_params="gz12eJxjYGBgkGAAgRNODESDBnsIHll8ANNSGQM="/>
...
<rdf:Seq>
</darktable:history>
...add some code
const assert = require('assert')
const { decodeExposureParams, encodeExposureParams } = require('@wmakeev/darkroom-xmp-tools')
// from XMP darktable:params
const EXPOSURE_PARAMS_BIN_STR = '0000000040a0093bd8ce374000004842000080c0'
let paramsObj = decodeExposureParams(EXPOSURE_PARAMS_BIN_STR)
console.log('exposureParams:', JSON.stringify(paramsObj))
// "exposureParams": {
// "mode": "EXPOSURE_MODE_MANUAL",
// "black": 0.0021000057458877563,
// "exposure": 2.871999740600586,
// "deflickerPercentile": 50,
// "deflickerTargetLevel": -4
// }
// before encode you can modify paramsObj ...
let encodedParamsStr = encodeExposureParams(paramsObj)
// ... and update exposure darktable:params in XMP file with new value
assert.strictEqual(encodedParamsStr, EXPOSURE_PARAMS_BIN_STR)API
Sharpen
decodeSharpenParams (encoded: string): SharpenParamsencodeSharpenParams (params: SharpenParams): string
Levels
decodeLevelsParams (encoded: string): LevelsParamsencodeLevelsParams (params: LevelsParams): string
Shadhi
decodeShadhiParams (encoded: string): ShadhiParamsencodeShadhiParams (params: ShadhiParams): string
Exposure
decodeExposureParams (encoded: string): ExposureParamsencodeExposureParams (params: ExposureParams): string
Blend
decodeBlendParams (encoded: string): BlendParamsencodeBlendParams (params: BlendParams): string
Clipping
decodeClippingParams (encoded: string): ClippingParamsencodeClippingParams (params: ClippingParams): string
Defringe
decodeDefringeParams (encoded: string): DefringeParamsencodeDefringeParams (params: DefringeParams): string
Flip
decodeFlipParams (encoded: string): FlipParamsencodeFlipParams (params: FlipParams): string
Basecurve
decodeBasecurveParams (encoded: string): BasecurveencodeBasecurveParams (params: Basecurve): string
Common
decodeParams (operation: 'sharpen', encodedParams: string): SharpenParamsdecodeParams (operation: 'levels', encodedParams: string): LevelsParamsdecodeParams (operation: 'shadhi', encodedParams: string): ShadhiParamsdecodeParams (operation: 'exposure', encodedParams: string): ExposureParamsdecodeParams (operation: 'blend', encodedParams: string): BlendParamsdecodeParams (operation: 'clipping', encodedParams: string): ClippingParamsdecodeParams (operation: 'defringe', encodedParams: string): DefringeParamsdecodeParams (operation: 'flip', encodedParams: string): FlipParamsdecodeParams (operation: 'basecurve', encodedParams: string): BasecurveParamsencodeParams (operation: string, params: Params): string
Masks
decodeMaskPoints<MaskPoint> (maskType: string, numberPoints: number, encodedPoints: string): Array<MaskPoint>encodeMaskPoints<MaskPoint> (maskType: string, points: Array<MaskPoint>): string
circle mask
decodeCircleMask (encodedMask: string): MaskCirclePointencodeCircleMask (mask: MaskCirclePoint): string
ellipse mask
decodeEllipseMask (encodedMask: string): MaskEllipsePointencodeEllipseMask (mask: MaskEllipsePoint): string
gradient mask
decodeGradientMask (encodedMask: string): MaskGradientPointencodeGradientMask (mask: MaskGradientPoint): string
Dependencies
TODO
- Windows support?
- Improve errors messages and arguments validation
Changes
2.0.2
- Fix Typescript typings
- Add Travis build
2.0.1
- Add Linux support
- Add some arguments validation
- Fix some bugs
