Browse Source

UTIF 추가

3cooking 5 years ago
parent
commit
c798e5005d

+ 1 - 0
mplus-fatima/WebContent/resources/plugins/UTIF/.gitignore

@@ -0,0 +1 @@
+node_modules

+ 21 - 0
mplus-fatima/WebContent/resources/plugins/UTIF/LICENSE

@@ -0,0 +1,21 @@
+MIT License
+
+Copyright (c) 2017 Photopea
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.

+ 79 - 0
mplus-fatima/WebContent/resources/plugins/UTIF/README.md

@@ -0,0 +1,79 @@
+# UTIF.js
+A small, fast and advanced TIFF / EXIF (+ DNG, CR2, NEF and other TIFF-ish files) decoder and encoder. It is the main TIFF library for [Photopea image editor](https://www.photopea.com). Try to open your TIFF file with Photopea to see, if UTIF.js can parse it.
+
+* Supports Black & White, Grayscale, RGB and Paletted images
+* Supports Fax 3 and Fax 4 (CCITT), JPEG, LZW, PackBits and other compressions (1,3,4,5,6,7,8,32773,32809)
+* E.g. [this 8 MPix image](//www.photopea.com/api/img2/G4.TIF) with Fax 4 compression is just 56 kB ( [Open in Photopea](https://www.photopea.com?p=%7B%22files%22:%5B%22//www.photopea.com/api/img2/G4.TIF%22%5D%7D) )
+
+For RAW files, UTIF.js only decodes raw sensor data (and JPG previews, if there are any). It does not convert the raw data into a displayable image (RGBA). Such conversion is complex and out of scope of this library.
+
+## Installation
+
+Download and include the `UTIF.js` file in your code. If you're in NodeJS or otherwise using NPM, run:
+
+```sh
+npm install utif
+```
+
+#### `UTIF.decode(buffer)`
+* `buffer`: ArrayBuffer containing TIFF or EXIF data
+* returns an array of "IFDs" (image file directories). Each IFD is an object, keys are "tXYZ" (XYZ is a TIFF tag number), values are values of these tags. You can get the the dimension (and other properties, "metadata") of the image without decompressing pixel data.
+
+#### `UTIF.decodeImage(buffer, ifd)`
+* `buffer`: ArrayBuffer containing TIFF or EXIF data
+* `ifd`: the element of the output of UTIF.decode()
+* If there is an image inside the IFD, it is decoded and three new properties are added to the IFD:
+* * `width`: the width of the image
+* * `height`: the height of the image
+* * `data`: decompressed pixel data of the image
+
+TIFF files may have various number of channels and various color depth. The interpretation of `data` depends on many tags (see the [TIFF 6 specification](http://www.npes.org/pdf/TIFF-v6.pdf)). The following function converts any TIFF image into a 8-bit RGBA image.
+
+#### `UTIF.toRGBA8(ifd)`
+* `ifd`: image file directory (element of "ifds" returned by UTIF.decode(), processed by UTIF.decodeImage())
+* returns Uint8Array of the image in RGBA format, 8 bits per channel (ready to use in context2d.putImageData() etc.)
+
+### Example
+
+```javascript
+function imgLoaded(e) {
+  var ifds = UTIF.decode(e.target.response);
+  UTIF.decodeImage(e.target.response, ifds[0])
+  var rgba  = UTIF.toRGBA8(ifds[0]);  // Uint8Array with RGBA pixels
+  console.log(ifds[0].width, ifds[0].height, ifds[0]);
+}
+
+var xhr = new XMLHttpRequest();
+xhr.open("GET", "my_image.tif");
+xhr.responseType = "arraybuffer";
+xhr.onload = imgLoaded;   xhr.send();
+```
+## Use TIFF images in HTML
+
+If you are not a programmer, you can use TIFF images directly inside the `<img>` element of HTML. Then, it is enough to call `UTIF.replaceIMG()` once at some point.
+
+#### `UTIF.replaceIMG()`
+```html
+<body onload="UTIF.replaceIMG()">
+...
+<img src="image.tif" />  <img src="dog.tif" /> ...
+```
+And UTIF.js will do the rest. Internally, the "src" attribute of the image will be replaced with a new URI of the image (base64-encoded PNG). Note, that you can also insert DNG, CR2, NEF and other raw images into HTML this way.
+
+## Encoding TIFF images
+
+You should not save images into TIFF format in the 21st century. Save them as PNG instead (e.g. using [UPNG.js](https://github.com/photopea/UPNG.js)). If you still want to use TIFF format for some reason, here it is.
+
+#### `UTIF.encodeImage(rgba, w, h, metadata)`
+* `rgba`: ArrayBuffer containing RGBA pixel data
+* `w`: image width
+* `h`: image height
+* `metadata` [optional]: IFD object (see below)
+* returns ArrayBuffer of the binary TIFF file. No compression right now.
+
+#### `UTIF.encode(ifds)`
+* `ifds`: array of IFDs (image file directories). An IFD is a JS object with properties "tXYZ" (where XYZ are TIFF tags)
+* returns ArrayBuffer of binary data. You can use it to encode EXIF data.
+
+## Dependencies
+TIFF format sometimes uses Inflate algorithm for compression (but it is quite rare). Right now, UTIF.js calls [Pako.js](https://github.com/nodeca/pako) for the Inflate method.

File diff suppressed because it is too large
+ 1169 - 0
mplus-fatima/WebContent/resources/plugins/UTIF/UTIF.js


+ 13 - 0
mplus-fatima/WebContent/resources/plugins/UTIF/package-lock.json

@@ -0,0 +1,13 @@
+{
+  "name": "utif",
+  "version": "1.3.0",
+  "lockfileVersion": 1,
+  "requires": true,
+  "dependencies": {
+    "pako": {
+      "version": "1.0.6",
+      "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.6.tgz",
+      "integrity": "sha512-lQe48YPsMJAig+yngZ87Lus+NF+3mtu7DVOBu6b/gHO1YpKwIj5AWjZ/TOS7i46HD/UixzWb1zeWDZfGZ3iYcg=="
+    }
+  }
+}

+ 24 - 0
mplus-fatima/WebContent/resources/plugins/UTIF/package.json

@@ -0,0 +1,24 @@
+{
+  "name": "utif",
+  "description": "Fast and advanced TIFF decoder",
+  "version": "3.1.0",
+  "homepage": "https://github.com/photopea/UTIF.js",
+  "author": "photopea (https://github.com/photopea)",
+  "contributors": [
+    "Scimonster (https://github.com/Scimonster)"
+  ],
+  "license": "MIT",
+  "repository": "github:photopea/UTIF.js",
+  "bugs": {
+    "url": "https://github.com/photopea/UTIF.js/issues"
+  },
+  "main": "UTIF",
+  "keywords": [
+    "tiff",
+    "image",
+    "conversion"
+  ],
+  "dependencies": {
+    "pako": "^1.0.5"
+  }
+}