using CitablePhysicalText, CitableBase
= joinpath(repo, "test", "assets", "burney86-sample.cex")
f = fromcex(f, Codex, FileReader)[1] ms
Generating IIIF manifests for a codex
When you model a codex, you document each page with an image. If the images are available from a server supporting the image serving protocol of the IIIF (International Image Interoperability Framework), you can easily share a catalog of the images as a IIIF Presentation Manifest presenting the sequence of the manuscript’s pages in order. In this tutorial, we’ll see how to use the iiifmanifest
function to create a IIIF manifest for a codex, then serve the manifest from a platform like github to use it from anyone’s IIIF application.
- See this tutorial to get started with codices (books) and pages.
- Seen an introduction to how the IIIF protocols work
Prerequisites
We need:
- the data from the codex model
- the IIIF image service where the images are available
- information for configuring the Manifest.
The codex data
We’ll read the sample model of a codex from a file in this project’s github repository. See this tutorial for more details.
The IIIF image service
We’ll use the IIIFservice
type from the CitableImage
package: see the package documentation for more details.
using CitableImage
= "http://www.homermultitext.org/iipsrv"
imgsvc_baseurl = "/project/homer/pyramidal/deepzoom"
imgsvc_root = IIIFservice(imgsvc_baseurl, imgsvc_root) imgsvc
IIIFservice("http://www.homermultitext.org/iipsrv", "/project/homer/pyramidal/deepzoom")
Configuring the manifest
Every manifest must have a unique
= "https://raw.githubusercontent.com/cite-architecture/CitablePhysicalText.jl/refs/heads/main/test/assets/burney86samplemanifest.json"
manifesturl = iiifconfig(manifesturl) conf
Configuration for IIIF manifest with ID https://raw.githubusercontent.com/cite-architecture/CitablePhysicalText.jl/refs/heads/main/test/assets/burney86samplemanifest.json
You can use the IIIFConfig
object to manually configure many values in the IIIF Presentation Manifest. The manifest identifies a series of Canvas objects, each containing an AnnotationPage, which in turn contains an Annotation to paint the containing Canvas. You can configure collection names for each of these types of objects. See details in the API documentation.
Generating the manifest
With these parameters defined, we can get the JSON text of a manifest for our codex:
= iiifmanifest(ms, conf, imgsvc) manifestjson
When the manifest is composed, the image for each page is tested by querying the IIIF server to get the image’s dimensions. For a long manuscript or book, this can take some time, especially if the connection to the server is not fast.
You can, however, be sure that every entry in the manifest describes a legitimate image on the configured server.
Publishing and using the manifest
Now all we need to do is serve the text on the internet, preferably with support for COR. Github can do this for us: we’ll write the output to the same directory where we kept our source data for the codex.
= joinpath(repo, "test", "assets", "burney86samplemanifest.json")
outfile open(outfile,"w") do io
write(io, manifestjson)
end
We’ve pushed this to our repository so that it is available at this URL:
https://raw.githubusercontent.com/cite-architecture/CitablePhysicalText.jl/refs/heads/main/test/assets/burney86samplemanifest.json
Use that with any IIIF viewer (like these).
Here’s our manifest displayed in the Tify viewer: