Initial commit
This commit is contained in:
commit
9d51c7b1a4
2 changed files with 246 additions and 0 deletions
129
index.php
Normal file
129
index.php
Normal file
|
@ -0,0 +1,129 @@
|
|||
<?php
|
||||
header('Content-Type: text/html; charset=utf-8');
|
||||
header('Expires: '.gmdate('D, d M Y H:i:s \G\M\T', time() + 3600));
|
||||
?>
|
||||
<html>
|
||||
<head>
|
||||
<style type="text/css">
|
||||
img {
|
||||
border: 0;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
.square {
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.image {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
display: table-cell;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<?php
|
||||
|
||||
function getPreview($imgFile, $maxSize)
|
||||
{
|
||||
# example: data/myalbum/100.mypic.jpg
|
||||
$newImgFile = "data/".dirname($imgFile)."/".$maxSize.".".basename($imgFile);
|
||||
|
||||
if (! is_file($newImgFile))
|
||||
{
|
||||
$img = imagecreatefromjpeg($imgFile);
|
||||
|
||||
$w = imagesx($img);
|
||||
$h = imagesy($img);
|
||||
# don't do anything if the image is already small
|
||||
if ($w <= $maxSize and $h <= $maxSize) {
|
||||
imagedestroy($img);
|
||||
return $imgFile;
|
||||
}
|
||||
|
||||
# create the thumbs directory recursively
|
||||
if (! is_dir(dirname($newImgFile))) mkdir(dirname($newImgFile), 0777, true);
|
||||
|
||||
if ($w > $h) {
|
||||
$newW = $maxSize;
|
||||
$newH = $h/($w/$maxSize);
|
||||
} else {
|
||||
$newW = $w/($h/$maxSize);
|
||||
$newH = $maxSize;
|
||||
}
|
||||
|
||||
$newImg = imagecreatetruecolor($newW, $newH);
|
||||
|
||||
imagecopyresampled($newImg, $img, 0, 0, 0, 0, $newW, $newH, $w, $h);
|
||||
|
||||
imagejpeg($newImg, $newImgFile);
|
||||
|
||||
imagedestroy($img);
|
||||
imagedestroy($newImg);
|
||||
}
|
||||
|
||||
return dirname($_SERVER["SCRIPT_NAME"])."/".$newImgFile;
|
||||
}
|
||||
|
||||
function getAlbumPreview($dir)
|
||||
{
|
||||
foreach (scandir($dir) as $file) if ($file != '.' and $file != '..') {
|
||||
if (mime_content_type("$dir/$file") == "image/jpeg")
|
||||
return getPreview("$dir/$file", 100);
|
||||
}
|
||||
|
||||
return '';
|
||||
}
|
||||
|
||||
$shortPath = isset($_SERVER["PATH_INFO"]) ? $_SERVER["PATH_INFO"] : "";
|
||||
if ($shortPath == '/') $shortPath = '';
|
||||
$scriptUrlPath = substr($_SERVER["SCRIPT_NAME"], 0, -4); // trim .php
|
||||
|
||||
$imageFiles = array();
|
||||
$otherFiles = array();
|
||||
|
||||
$realDir = "images$shortPath";
|
||||
|
||||
foreach (scandir($realDir) as $file) if ($file != '.')
|
||||
{
|
||||
if ($file == '..')
|
||||
{
|
||||
echo "<div><a href=\"$scriptUrlPath".dirname($shortPath)."/\">..</a></div>\n";
|
||||
}
|
||||
elseif (is_dir("$realDir/$file"))
|
||||
{
|
||||
echo "<div>";
|
||||
$preview = getAlbumPreview("$realDir/$file");
|
||||
if ($preview !== '') {
|
||||
echo "<img src=\"$preview\" /> ";
|
||||
}
|
||||
|
||||
echo "<a href=\"$scriptUrlPath$shortPath/$file\">$file</a>";
|
||||
echo "</div>\n";
|
||||
}
|
||||
else
|
||||
{
|
||||
$mime = mime_content_type("$realDir/$file");
|
||||
|
||||
if ($mime == "image/jpeg")
|
||||
$imageFiles[] = $file;
|
||||
else
|
||||
$otherFiles[] = $file;
|
||||
}
|
||||
}
|
||||
|
||||
foreach ($imageFiles as $file) {
|
||||
echo "<div class=\"square\"><div class=\"image\"><a href=\"".dirname($scriptUrlPath)."/view/$shortPath/$file\"><img src=\"".getPreview("$realDir/$file", 100)."\" /></a></div></div>\n";
|
||||
}
|
||||
|
||||
foreach ($otherFiles as $file) {
|
||||
echo "<div><a href=\"".dirname($scriptUrlPath)."/$realDir/$file\">$file</a></div>\n";
|
||||
}
|
||||
|
||||
?>
|
||||
|
||||
</body>
|
||||
</html>
|
117
view.php
Normal file
117
view.php
Normal file
|
@ -0,0 +1,117 @@
|
|||
<?php
|
||||
|
||||
$quickPath = isset($_SERVER["PATH_INFO"])?$_SERVER["PATH_INFO"]:"";
|
||||
$scriptPath = $_SERVER["SCRIPT_NAME"];
|
||||
|
||||
$quickDir = dirname($quickPath);
|
||||
$realDir = "images$quickDir";
|
||||
|
||||
$files = scandir($realDir);
|
||||
$size = count($files);
|
||||
|
||||
$pos = array_search(basename($quickPath),$files);
|
||||
|
||||
$nextImage = '';
|
||||
for ($next=$pos+1; $nextImage === '' and $next<$size ; $next++) {
|
||||
$mime = mime_content_type("$realDir/$files[$next]");
|
||||
if ($mime == "image/jpeg")
|
||||
$nextImage = $files[$next];
|
||||
}
|
||||
|
||||
$prevImage = '';
|
||||
for ($prev=$pos-1; $prevImage === '' and $prev>=0 ; $prev--) {
|
||||
$mime = mime_content_type("$realDir/$files[$prev]");
|
||||
if ($mime == "image/jpeg")
|
||||
$prevImage = $files[$prev];
|
||||
}
|
||||
|
||||
$imageUrl = dirname($scriptPath)."/images$quickPath";
|
||||
|
||||
if ($nextImage === '') {
|
||||
$nextImageUrl = '';
|
||||
$nextPageUrl = '';
|
||||
} else {
|
||||
$nextImageUrl = dirname($scriptPath)."/images".dirname($quickPath)."/$nextImage";
|
||||
$nextPageUrl = dirname($_SERVER["REQUEST_URI"])."/$nextImage";
|
||||
}
|
||||
if ($prevImage === '') $prevPageUrl = '';
|
||||
else $prevPageUrl = dirname($_SERVER["REQUEST_URI"])."/$prevImage";
|
||||
|
||||
$directoryUrl = dirname($_SERVER["SCRIPT_NAME"])."/index".dirname($quickPath);
|
||||
|
||||
header('Content-Type: text/html; charset=utf-8');
|
||||
header('Expires: '.gmdate('D, d M Y H:i:s \G\M\T', time() + 3600));
|
||||
?>
|
||||
<html>
|
||||
<head>
|
||||
<style type="text/css">
|
||||
html, body {
|
||||
height: 100%;
|
||||
}
|
||||
body {
|
||||
margin: 0;
|
||||
text-align: center;
|
||||
background: black;
|
||||
color: white;
|
||||
}
|
||||
#theimage {
|
||||
max-width: 100%;
|
||||
max-height: 100%;
|
||||
}
|
||||
a {
|
||||
color: white;
|
||||
text-decoration: none;
|
||||
}
|
||||
#next, #previous, #up {
|
||||
position: fixed;
|
||||
font-size: 4em;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
#up {
|
||||
top: 0;
|
||||
left: 0;
|
||||
|
||||
}
|
||||
#next {
|
||||
top: 50%;
|
||||
right: -0;
|
||||
|
||||
}
|
||||
#previous {
|
||||
top: 50%;
|
||||
left: 0;
|
||||
}
|
||||
img {
|
||||
border: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
<?php if ($nextImageUrl !== '') { ?>
|
||||
<link rel="prefetch" href="<?php echo $nextImageUrl ?>" />
|
||||
<link rel="prefetch" href="<?php echo $nextPageUrl ?>" />
|
||||
<?php } ?>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<a href="<?php echo $imageUrl ?>"><img src="<?php echo $imageUrl ?>" id="theimage" /></a>
|
||||
|
||||
<div id="up">
|
||||
<a href="<?php echo $directoryUrl ?>" title="Back to directory">^</a>
|
||||
</div>
|
||||
|
||||
<?php if ($nextPageUrl !== '') { ?>
|
||||
<div id="next">
|
||||
<a href="<?php echo $nextPageUrl ?>" title="Next image">></a>
|
||||
</div>
|
||||
<?php } ?>
|
||||
|
||||
<?php if ($prevPageUrl !== '') { ?>
|
||||
<div id="previous">
|
||||
<a href="<?php echo $nextPageUrl ?>" title="Previous image"><</a>
|
||||
</div>
|
||||
<?php } ?>
|
||||
|
||||
</body>
|
||||
</html>
|
Loading…
Reference in a new issue