blob: c7dba76f523f0df8b2d8c6cf3ce698059b3c73dd [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* $Id$ */
package xmp;
import java.net.URL;
import javax.xml.transform.TransformerException;
import javax.xml.transform.stream.StreamResult;
import org.xml.sax.SAXException;
import org.apache.xmlgraphics.xmp.Metadata;
import org.apache.xmlgraphics.xmp.XMPArray;
import org.apache.xmlgraphics.xmp.XMPConstants;
import org.apache.xmlgraphics.xmp.XMPParser;
import org.apache.xmlgraphics.xmp.XMPProperty;
import org.apache.xmlgraphics.xmp.XMPSerializer;
import org.apache.xmlgraphics.xmp.schemas.DublinCoreAdapter;
import org.apache.xmlgraphics.xmp.schemas.DublinCoreSchema;
/**
* This example shows how to parse an XMP metadata file.
*/
public class ParseMetadata {
private static void parseMetadata() throws TransformerException, SAXException {
URL url = ParseMetadata.class.getResource("pdf-example.xmp");
Metadata meta = XMPParser.parseXMP(url);
XMPProperty prop;
prop = meta.getProperty(XMPConstants.DUBLIN_CORE_NAMESPACE, "creator");
XMPArray array;
array = prop.getArrayValue();
for (int i = 0, c = array.getSize(); i < c; i++) {
System.out.println("Creator: " + array.getValue(i));
}
prop = meta.getProperty(XMPConstants.DUBLIN_CORE_NAMESPACE, "title");
array = prop.getArrayValue();
System.out.println("Default Title: " + array.getSimpleValue());
System.out.println("German Title: " + array.getLangValue("de"));
prop = meta.getProperty(XMPConstants.XMP_BASIC_NAMESPACE, "CreateDate");
System.out.println("Creation Date: " + prop.getValue());
prop = meta.getProperty(XMPConstants.XMP_BASIC_NAMESPACE, "CreatorTool");
System.out.println("Creator Tool: " + prop.getValue());
prop = meta.getProperty(XMPConstants.ADOBE_PDF_NAMESPACE, "Producer");
System.out.println("Producer: " + prop.getValue());
prop = meta.getProperty(XMPConstants.ADOBE_PDF_NAMESPACE, "PDFVersion");
System.out.println("PDF version: " + prop.getValue());
DublinCoreAdapter dc = DublinCoreSchema.getAdapter(meta);
System.out.println("Default title: " + dc.getTitle());
System.out.println("German title: " + dc.getTitle("de"));
StreamResult res = new StreamResult(System.out);
XMPSerializer.writeXML(meta, res);
}
/**
* Command-line interface.
* @param args the command-line arguments
*/
public static void main(String[] args) {
try {
parseMetadata();
} catch (Exception e) {
e.printStackTrace();
}
}
}