view Resources/TestIIIFTiles.py @ 355:a307ec25a008

padding for on-the-fly pyramids
author Sebastien Jodogne <s.jodogne@gmail.com>
date Fri, 20 Dec 2024 13:48:34 +0100
parents 2805246064aa
children
line wrap: on
line source

#!/usr/bin/env python3

import requests
import sys

if len(sys.argv) != 2:
    print('Usage: %s <URL to info.json>' % sys.argv[0])
    exit(-1)

r = requests.get(sys.argv[1])
r.raise_for_status()

info = r.json()

assert(len(info['tiles']) == 1)
assert(len(info['tiles'][0]['scaleFactors']) == len(info['sizes']))

width = None
height = None
for size in info['sizes']:
    if (width == None or
        size['width'] > width):
        width = size['width']
        height = size['height']

tw = info['tiles'][0]['width']
th = info['tiles'][0]['height']

assert(isinstance(width, int))
assert(isinstance(height, int))
assert(isinstance(tw, int))
assert(isinstance(th, int))

def CeilingDivision(a, b):
    if a % b == 0:
        return a // b
    else:
        return a // b + 1

for s in info['tiles'][0]['scaleFactors']:
    assert(isinstance(s, int))

    countTilesX = CeilingDivision(width, tw * s)
    countTilesY = CeilingDivision(height, th * s)
    print(tw * s, th * s, countTilesX, countTilesY)

    for m in range(countTilesY):
        for n in range(countTilesX):

            # Reference:
            # https://iiif.io/api/image/3.0/implementation/#3-tile-region-parameter-calculation

            # Calculate region parameters /xr,yr,wr,hr/
            xr = n * tw * s
            yr = m * th * s
            wr = tw * s
            if (xr + wr > width):
                wr = width - xr
            hr = th * s
            if (yr + hr > height):
                hr = height - yr

            # Calculate size parameters /ws,hs/
            ws = tw
            if (xr + tw*s > width):
                ws = (width - xr + s - 1) / s  # +s-1 in numerator to round up
            hs = th
            if (yr + th*s > height):
                hs = (height - yr + s - 1) / s

            url = '%s/%d,%d,%d,%d/%d,%d/0/default.jpg' % (info['id'], xr, yr, wr, hr, ws, hs)
            r = requests.get(url)

            if r.status_code == 200:
                print('SUCCESS: %s' % url)
            else:
                print('ERROR:   %s' % url)