mirror of
https://github.com/openseadragon/openseadragon.git
synced 2024-11-30 09:06:08 +03:00
382 lines
12 KiB
JavaScript
382 lines
12 KiB
JavaScript
/* globals $, App */
|
|
|
|
(function() {
|
|
|
|
window.App = {
|
|
init: function() {
|
|
var self = this;
|
|
|
|
var testInitialOpen = true;
|
|
var testOverlays = false;
|
|
var testMargins = false;
|
|
var testNavigator = false;
|
|
var margins;
|
|
|
|
var config = {
|
|
// debugMode: true,
|
|
zoomPerScroll: 1.02,
|
|
showNavigator: testNavigator,
|
|
useCanvas: true,
|
|
// defaultZoomLevel: 2,
|
|
// homeFillsViewer: true,
|
|
// sequenceMode: true,
|
|
// showReferenceStrip: true,
|
|
// referenceStripScroll: 'vertical',
|
|
navPrevNextWrap: false,
|
|
preserveViewport: false,
|
|
// collectionMode: true,
|
|
// collectionRows: 1,
|
|
// collectionLayout: 'vertical',
|
|
// collectionTileSize: 10,
|
|
// collectionTileMargin: 10,
|
|
// wrapHorizontal: true,
|
|
// wrapVertical: true,
|
|
id: "contentDiv",
|
|
prefixUrl: "../../../build/openseadragon/images/"
|
|
};
|
|
|
|
var highsmith = {
|
|
Image: {
|
|
xmlns: "http://schemas.microsoft.com/deepzoom/2008",
|
|
Url: "http://openseadragon.github.io/example-images/highsmith/highsmith_files/",
|
|
Format: "jpg",
|
|
Overlap: "2",
|
|
TileSize: "256",
|
|
Size: {
|
|
Height: "9221",
|
|
Width: "7026"
|
|
}
|
|
}
|
|
};
|
|
|
|
if (testInitialOpen) {
|
|
config.tileSources = [
|
|
{
|
|
tileSource: "../../data/testpattern.dzi",
|
|
x: 4,
|
|
y: 2,
|
|
width: 2
|
|
},
|
|
{
|
|
tileSource: "../../data/tall.dzi",
|
|
x: 1.5,
|
|
y: 0,
|
|
width: 1
|
|
},
|
|
{
|
|
tileSource: '../../data/wide.dzi',
|
|
opacity: 1,
|
|
x: 0,
|
|
y: 1.5,
|
|
height: 1
|
|
}
|
|
];
|
|
|
|
// config.tileSources = {
|
|
// tileSource: highsmith,
|
|
// width: 1
|
|
// };
|
|
}
|
|
|
|
if (testOverlays) {
|
|
config.overlays = [
|
|
{
|
|
id: "overlay1",
|
|
x: 2,
|
|
y: 0,
|
|
width: 0.25,
|
|
height: 0.25
|
|
},
|
|
{
|
|
px: 13,
|
|
py: 120,
|
|
width: 124,
|
|
height: 132,
|
|
id: "overlay"
|
|
},
|
|
{
|
|
px: 400,
|
|
py: 500,
|
|
width: 400,
|
|
height: 400,
|
|
id: "fixed-overlay",
|
|
placement: "TOP_LEFT"
|
|
}
|
|
];
|
|
}
|
|
|
|
if (testMargins) {
|
|
margins = {
|
|
top: 250,
|
|
left: 250,
|
|
right: 250,
|
|
bottom: 250
|
|
};
|
|
|
|
config.viewportMargins = margins;
|
|
}
|
|
|
|
this.viewer = OpenSeadragon(config);
|
|
|
|
if (testInitialOpen) {
|
|
function openHandler() {
|
|
self.viewer.removeHandler('open', openHandler);
|
|
}
|
|
|
|
this.viewer.addHandler( "open", openHandler);
|
|
}
|
|
|
|
if (testMargins) {
|
|
this.viewer.addHandler('animation', function() {
|
|
var box = new OpenSeadragon.Rect(margins.left, margins.top,
|
|
$('#contentDiv').width() - (margins.left + margins.right),
|
|
$('#contentDiv').height() - (margins.top + margins.bottom));
|
|
|
|
self.viewer.drawer.debugRect(box);
|
|
});
|
|
}
|
|
|
|
if (!testInitialOpen) {
|
|
this.basicTest();
|
|
}
|
|
},
|
|
|
|
// ----------
|
|
shrink: function(index) {
|
|
index = index || 0;
|
|
var image = this.viewer.world.getItemAt(index);
|
|
image.setWidth(image.getBounds().width * 0.3);
|
|
},
|
|
|
|
// ----------
|
|
move: function(index) {
|
|
index = index || 0;
|
|
var image = this.viewer.world.getItemAt(index);
|
|
var point = image.getBounds().getTopLeft();
|
|
point.x += image.getBounds().width * 0.3;
|
|
image.setPosition(point);
|
|
},
|
|
|
|
// ----------
|
|
add: function() {
|
|
var self = this;
|
|
|
|
this.viewer.addTiledImage({
|
|
tileSource: "../../data/testpattern.dzi",
|
|
width: 1,
|
|
success: function() {
|
|
self.viewer.viewport.goHome();
|
|
}
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
toggle: function() {
|
|
var $el = $(this.viewer.element);
|
|
$el.toggleClass('small');
|
|
},
|
|
|
|
// ----------
|
|
basicTest: function() {
|
|
var self = this;
|
|
|
|
this.viewer.addHandler('open', function() {
|
|
});
|
|
|
|
this.viewer.open({
|
|
tileSource: "../../data/testpattern.dzi",
|
|
width: 1
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
crossTest: function() {
|
|
var self = this;
|
|
|
|
this.viewer.addHandler( "open", function() {
|
|
var options = {
|
|
tileSource: '../../data/wide.dzi',
|
|
opacity: 1,
|
|
x: 0,
|
|
y: 1.5,
|
|
height: 1
|
|
};
|
|
|
|
var addItemHandler = function( event ) {
|
|
if ( event.options === options ) {
|
|
self.viewer.world.removeHandler( "add-item", addItemHandler );
|
|
self.viewer.viewport.goHome();
|
|
}
|
|
};
|
|
self.viewer.world.addHandler( "add-item", addItemHandler );
|
|
self.viewer.addTiledImage( options );
|
|
});
|
|
|
|
this.viewer.open({
|
|
tileSource: "../../data/tall.dzi",
|
|
x: 1.5,
|
|
y: 0,
|
|
width: 1
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
crossTest2: function() {
|
|
this.viewer.open([
|
|
{
|
|
tileSource: "../../data/tall.dzi",
|
|
x: 1.5,
|
|
y: 0,
|
|
width: 1
|
|
},
|
|
{
|
|
tileSource: '../../data/wide.dzi',
|
|
x: 0,
|
|
y: 1.5,
|
|
height: 1
|
|
}
|
|
]);
|
|
},
|
|
|
|
// ----------
|
|
crossTest3: function() {
|
|
var self = this;
|
|
var expected = 2;
|
|
var loaded = 0;
|
|
|
|
this.viewer.world.addHandler('add-item', function() {
|
|
loaded++;
|
|
if (loaded === expected) {
|
|
// self.viewer.viewport.goHome();
|
|
}
|
|
});
|
|
|
|
this.viewer.addTiledImage({
|
|
tileSource: "../../data/tall.dzi",
|
|
x: 1.5,
|
|
y: 0,
|
|
width: 1
|
|
});
|
|
|
|
this.viewer.addTiledImage({
|
|
tileSource: '../../data/wide.dzi',
|
|
opacity: 1,
|
|
x: 0,
|
|
y: 1.5,
|
|
height: 1
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
collectionTest: function() {
|
|
var tileSources = [];
|
|
var random;
|
|
for (var i = 0; i < 10; i++) {
|
|
random = Math.random();
|
|
if (random < 0.33) {
|
|
tileSources.push('../../data/testpattern.dzi');
|
|
} else if (random < 0.66) {
|
|
tileSources.push('../../data/tall.dzi');
|
|
} else {
|
|
tileSources.push('../../data/wide.dzi');
|
|
}
|
|
}
|
|
|
|
this.viewer.open(tileSources);
|
|
},
|
|
|
|
// ----------
|
|
gridTest: function() {
|
|
var self = this;
|
|
var startX = -3;
|
|
var expected = 0;
|
|
var loaded = 0;
|
|
|
|
this.viewer.addHandler( "open", function() {
|
|
self.viewer.world.addHandler('add-item', function() {
|
|
loaded++;
|
|
if (loaded === expected) {
|
|
self.viewer.viewport.goHome(true);
|
|
}
|
|
});
|
|
|
|
var x, y;
|
|
for (y = 0; y < 6; y++) {
|
|
for (x = 0; x < 6; x++) {
|
|
if (!x && !y) {
|
|
continue;
|
|
}
|
|
|
|
var options = {
|
|
tileSource: '../../data/testpattern.dzi',
|
|
x: startX + x,
|
|
y: y,
|
|
width: 1
|
|
};
|
|
|
|
expected++;
|
|
self.viewer.addTiledImage( options );
|
|
}
|
|
}
|
|
});
|
|
|
|
this.viewer.open({
|
|
tileSource: "../../data/testpattern.dzi",
|
|
x: startX,
|
|
y: 0,
|
|
width: 1
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
bigTest: function() {
|
|
this.viewer.open({
|
|
tileSource: "../../data/testpattern.dzi",
|
|
x: -2,
|
|
y: -2,
|
|
width: 6
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
cjTest: function() {
|
|
var imageKey = "e-pluribus-unum";
|
|
var imageXML = '<?xml version="1.0" encoding="UTF-8"?><Image TileSize="254" Overlap="1" Format="png" xmlns="http://schemas.microsoft.com/deepzoom/2008"><Size Width="88560" Height="88560"/></Image>';
|
|
var $xml = $($.parseXML(imageXML));
|
|
var $image = $xml.find('Image');
|
|
var $size = $xml.find('Size');
|
|
|
|
var dzi = {
|
|
Image: {
|
|
xmlns: $image.attr('xmlns'),
|
|
Url: "http://chrisjordan.com/dzi/" + imageKey + '_files/',
|
|
Format: $image.attr('Format'),
|
|
Overlap: $image.attr('Overlap'),
|
|
TileSize: $image.attr('TileSize'),
|
|
Size: {
|
|
Height: $size.attr('Height'),
|
|
Width: $size.attr('Width')
|
|
}
|
|
}
|
|
};
|
|
|
|
this.viewer.open({
|
|
tileSource: dzi,
|
|
width: 100
|
|
});
|
|
},
|
|
|
|
// ----------
|
|
stanfordTest: function() {
|
|
var info = {"@context":"http://library.stanford.edu/iiif/image-api/1.1/context.json","@id":"http://ids.lib.harvard.edu/ids/iiif/48530377","width":6251,"height":109517,"scale_factors":[1,2,4,8,16,32],"tile_width":256,"tile_height":256,"formats":["jpg"],"qualities":["native"],"profile":"http://library.stanford.edu/iiif/image-api/1.1/compliance.html#level1"};
|
|
|
|
this.viewer.open(info);
|
|
}
|
|
};
|
|
|
|
$(document).ready(function() {
|
|
App.init();
|
|
});
|
|
|
|
})();
|