PHP Галерея не правильно отображает первые два изображения в галерее - PullRequest
0 голосов
/ 02 января 2019

По какой-то причине первые два изображения в каждой галерее на моем сайте отображаются неправильно. Я посмотрел на странице источника и нашел это:

<td><a href="javascript:imgSubmit('image.php?gallery=053&imgnum=1');"><img src="/galleries/053/thumbs/." class="thumb_img" border="0" /></a></td>
<td><a href="javascript:imgSubmit('image.php?gallery=053&imgnum=2');"><img src="/galleries/053/thumbs/.." class="thumb_img" border="0" /></a></td>
<td><a href="javascript:imgSubmit('image.php?gallery=053&imgnum=3');"><img src="/galleries/053/thumbs/053img009.jpg" class="thumb_img" border="0" /></a></td>
<td><a href="javascript:imgSubmit('image.php?gallery=053&imgnum=4');"><img src="/galleries/053/thumbs/053img008.jpg" class="thumb_img" border="0" /></a></td>
<td><a href="javascript:imgSubmit('image.php?gallery=053&imgnum=5');"><img src="/galleries/053/thumbs/053img011.jpg" class="thumb_img" border="0" /></a></td> 

Я предполагаю, что это что-то в инициализации цикла FOR, но я не вижу здесь, но это явно неправильно для первых двух изображений. Вот соответствующий код в скрипте.

<?php

error_reporting(E_ALL);

require("config.php");
require("common.php");

$gallery    = $_GET['page'];
$gallerydir = DOC_ROOT . GALLERY_ROOT . '/' . $gallery;
$imglist    = getImageList($gallerydir);
$imgcnt     = count($imglist);

$currpage   = (isset($_GET['currpage'])) 
    ? (int) $_GET['currpage'] 
    : 1;

// get page elements 
$js          = getJavaScript($imglist);
$thumb_table = getThumbTableHTML($gallery, $imglist, $imgcnt, $currpage);
$image_cnt   = getImageRangeHTML($imgcnt, $currpage);
$page_nav    = getPageNavHTML($imgcnt, $currpage, $gallery);

// load template header and body 
$head = file_get_contents("./template/header.html");
$body = file_get_contents("./template/thumb_page.html");

// insert page elements 
$head = str_replace('<-- JAVASCRIPT -->', $js, $head);
$body = str_replace('<-- THUMBNAIL_TABLE -->', $thumb_table, $body);
$body = str_replace('<-- IMAGE_COUNT -->', $image_cnt, $body);
$body = str_replace('<-- PAGE_NAVIGATION -->', $page_nav, $body);

// output
echo $head;
echo $body;
//********************************************************************* 
// Begin thumbnail page related functions 
//*********************************************************************

function getImageRangeHTML($imgcnt, $currpage) {

    $max_per_page = TABLE_COLS * TABLE_ROWS;
    $pagecnt      = getThumbPageCount($imgcnt); 
    $first_image  = ($currpage - 1) * $max_per_page + 1;
    $last_image   = ($currpage == $pagecnt) 
        ? $imgcnt 
        : $currpage * $max_per_page;

    $str = "
        <font size=\"2\" face=\"Verdana, Geneva, sans-serif\"><i>
        $imgcnt images
        </i></font>
    ";

    return $str;
}
//********************************************************************* 

function getPageNavHTML($imgcnt, $currpage, $gallery) {

    $pagecnt  = getThumbPageCount($imgcnt); 
    $self     = $_SERVER['PHP_SELF'];

    // only proceed if there is more than 1 page of thumbs
    if ($pagecnt == 1) { return; }

    $str = "<ul>\n";

    for ($i = 1; $i <= $pagecnt; $i++) {

        if ($i == $currpage) {
            $str .= "<li class=\"active\">$i</li>";
        } else {
            $str .= "<li><a href=\"javascript:imgSubmit('$self?";
            $str .= "gallery=$gallery&currpage=$i');\">$i</a></li>";
        }
    }

    $str .= "</ul>\n";
    return $str;
}

//******************************************************************** 

function getThumbTableHTML($gallery, $imglist, $imgcnt, $currpage) {
    $max_per_page = TABLE_COLS * TABLE_ROWS;

    // set index of page's first image in image list array
    $first_image_index = ($currpage - 1) * $max_per_page;

    // set index of page's last image in image list array 
    $last_image_index = ($imgcnt < $currpage * $max_per_page)
        ? $last_image_index = $imgcnt
        : $currpage * $max_per_page;

    $str = '<table border="0" id="thumb_table">' . "\n";

    // loop control var
    $column_cnt  = 1;

    // loop through current page images
    for ($i = $first_image_index; $i < $last_image_index; $i++) {
        # build path to thumb
        $thumburl  = GALLERY_ROOT . "/$gallery/thumbs/" . $imglist[$i];

        // insert row tag if this is the first column
        if ($column_cnt == 1) { $str .= "<tr>\n"; }

        // insert thumbnail, and surrounding html
        $str .= "<td>";
        $str .= "<a href=\"javascript:imgSubmit('image.php?gallery=$gallery";
        $str .= "&imgnum=" . ($i + 1) . "');\">";
        $str .= "<img src=\"$thumburl\" class=\"thumb_img\" ";
        $str .= "border=\"0\" /></a>";
        $str .= "</td>\n";

        if ($column_cnt == TABLE_COLS) {
            $str .= "</tr>\n\n";
            $column_cnt = 1;
        } else {
            $column_cnt++;
        }
    }

    $str .= "</table>\n";
    return $str;
}

// ********************************************************************* 

function getThumbPageCount($imgcnt) {

    $page_cnt = (int) (($imgcnt - 1) / (TABLE_COLS * TABLE_ROWS)) + 1;
    return $page_cnt;
}

// ********************************************************************* 
?>

Вот соответствующий код для функции GetImageList ()

    function getImageList($gallerydir) {
        if (isset($_POST['imglist'])) {
            $imglist = $_POST['imglist'];
        } else {
            $fh = opendir("$gallerydir/thumbs");

            // read directory, and loop through retreived filenames
            while ($file = readdir($fh)) {
                // if image, add filename to image list 
                if (!preg_match("\.(jpg|gif|png|jpeg|jpe)$", $file)) {
                    $imglist[] = $file; 
                }
            }
            closedir($fh);
        }

        if (is_array($imglist)) {
            ksort($imglist);
        } else {
            $imglist = false;
        }
        return $imglist;
    }

//*********************************************************************
// Javascript writes image list as http posted array

function getJavaScript($imglist) {
    $str = '
    <script language="JavaScript">
    function imgSubmit(s) {
        document.img.method = "post";
        document.img.action = s;
        document.img.submit();
    }

    function imgList() {
    ';
    $str .= "\tvar imglist = new Array('" . implode("', '", $imglist) . "');\n";
    $str .= '
        for (var i=0; i < imglist.length; i++) {
            document.write ("<input type=\"hidden\" name=\"imglist[]\" ");
            document.write ("value=\"" + imglist[i] + "\" />"); 
        }
    }
    </script>
    ';
    return $str;
}

//*********************************************************************

?>
...