<?php
|
|
|
|
function wordWrapAnnotation(&$image, &$draw, $text, $maxWidth)
|
|
{
|
|
$words = explode(" ", $text);
|
|
$lines = array();
|
|
$i = 0;
|
|
$lineHeight = 0;
|
|
while($i < count($words) )
|
|
{
|
|
$currentLine = $words[$i];
|
|
if($i+1 >= count($words))
|
|
{
|
|
$lines[] = $currentLine;
|
|
break;
|
|
}
|
|
//Check to see if we can add another word to this line
|
|
$metrics = $image->queryFontMetrics($draw, $currentLine . ' '
|
|
. $words[$i+1]);
|
|
while($metrics['textWidth'] <= $maxWidth)
|
|
{
|
|
//If so, do it and keep doing it!
|
|
$currentLine .= ' ' . $words[++$i];
|
|
if($i+1 >= count($words))
|
|
break;
|
|
$metrics = $image->queryFontMetrics($draw, $currentLine . ' '
|
|
. $words[$i+1]);
|
|
}
|
|
//We can't add the next word to this line, so loop to the next line
|
|
$lines[] = $currentLine;
|
|
$i++;
|
|
//Finally, update line height
|
|
if($metrics['textHeight'] > $lineHeight)
|
|
$lineHeight = $metrics['textHeight'];
|
|
}
|
|
return array($lines, $lineHeight);
|
|
}
|
|
|
|
function displayImage($quote, $person, $imageLoc)
|
|
{
|
|
$draw = new ImagickDraw();
|
|
|
|
$image = new Imagick();
|
|
$image->readImage($imageLoc);
|
|
|
|
|
|
/* Green text */
|
|
$draw->setFillColor("rgb(0,255,0)");
|
|
|
|
/* Font properties */
|
|
$draw->setFont('Bookman-DemiItalic');
|
|
|
|
$fontsize = 0.05 * $image->getimagewidth();
|
|
|
|
$draw->setFontSize( "$fontsize" );
|
|
|
|
$xpos = $image->getimagewidth()/4;
|
|
$ypos = $image->getimageheight()/4;
|
|
|
|
|
|
$msg = '"' . $quote . '"' . " - $person";
|
|
|
|
list($lines, $lineHeight) = wordWrapAnnotation($image,
|
|
$draw, $msg, $image->getimagewidth() /2);
|
|
for($i = 0; $i < count($lines); $i++)
|
|
$image->annotateImage($draw, $xpos, $ypos + $i*$lineHeight,
|
|
0, $lines[$i]);
|
|
|
|
|
|
/* Give image a format */
|
|
$image->setImageFormat('png');
|
|
|
|
echo '<img src="data:image/jpg;base64,'.base64_encode(
|
|
$image->getImageBlob()).'" alt="" width="100%"/>';
|
|
}
|
|
function printHalf($query)
|
|
{
|
|
$r = mysqli_query ($dbc, $query);
|
|
|
|
while($row = mysqli_fetch_array($r))
|
|
{
|
|
$q2 = "select name from people where person_id='" .
|
|
$row['person_id'] . "' limit 1";
|
|
|
|
$r2 = mysqli_query($dbc, $q2);
|
|
|
|
while($row2 = mysqli_fetch_array($r2))
|
|
{
|
|
$images = glob('../img/*');
|
|
displayImage($row['quote'], $row2['name'],
|
|
$images[rand(0, count($images) - 1)]);
|
|
}
|
|
}
|
|
echo '</div>';
|
|
}
|
|
|
|
|
|
echo '<div class="w3-row-padding w3-center w3-margin-top">';
|
|
|
|
echo '<div class="w3-half">';
|
|
echo '<h1 class="w3-text-teal w3-center">Random Quote</h1>';
|
|
$q ="select * from quote where visibility=true order by rand() limit 1";
|
|
$r = mysqli_query ($dbc, $q);
|
|
|
|
while($row = mysqli_fetch_array($r))
|
|
{
|
|
$q2 = "select name from people where person_id='" . $row['person_id']
|
|
. "' limit 1";
|
|
|
|
$r2 = mysqli_query($dbc, $q2);
|
|
|
|
while($row2 = mysqli_fetch_array($r2))
|
|
{
|
|
$images = glob('../img/*');
|
|
displayImage($row['quote'], $row2['name'],
|
|
$images[rand(0, count($images) - 1)]);
|
|
}
|
|
}
|
|
echo '</div>';
|
|
echo '<div class="w3-half">';
|
|
echo '<h1 class="w3-text-teal w3-center">Most Recent</h1>';
|
|
$q ="select * from quote where visibility=true order by creation_date
|
|
desc limit 1";
|
|
$r = mysqli_query ($dbc, $q);
|
|
|
|
while($row = mysqli_fetch_array($r))
|
|
{
|
|
$q2 = "select name from people where person_id='" . $row['person_id']
|
|
. "' limit 1";
|
|
|
|
$r2 = mysqli_query($dbc, $q2);
|
|
|
|
while($row2 = mysqli_fetch_array($r2))
|
|
{
|
|
$images = glob('../img/*');
|
|
displayImage($row['quote'], $row2['name'],
|
|
$images[rand(0, count($images) - 1)]);
|
|
}
|
|
}
|
|
|
|
echo '</div>';
|
|
|
|
echo '</div>';
|
|
|
|
echo '<div class="w3-row-padding w3-center w3-margin-top">';
|
|
|
|
echo '<div class="w3-half row-center">';
|
|
|
|
if(isset($_POST['panda']))
|
|
{
|
|
displayImage($_POST['panda_quote'], $_POST['panda_name'],
|
|
$images[rand(0, count($images) - 1)]);
|
|
}
|
|
echo '<h1 class="w3-text-teal w3-center">Create a panda quote!</h1>';
|
|
|
|
|
|
|
|
echo '<form action="index.php" method ="post" class="w3-container w3-card-4">
|
|
|
|
<div class="w3-group">
|
|
<input class="w3-input" type="text" name="panda_quote" required>
|
|
<label class="w3-label w3-validate">Quote</label>
|
|
</div>
|
|
<div class="w3-group">
|
|
<input class="w3-input" type="text" name="panda_name" required>
|
|
<label class="w3-label w3-validate">Person\'s Name</label>
|
|
</div>
|
|
<p><input type="submit" name="Submit" value="Create Panda Quote"
|
|
class="w3-padding-16 w3-hover-dark-grey w3-btn-block w3-center-align" /></p>
|
|
<input type="hidden" name="panda" value="TRUE" />
|
|
|
|
|
|
</form>';
|
|
|
|
|
|
echo '</div>';
|
|
|
|
echo '<div class="w3-half w3-container">';
|
|
//profile
|
|
include('user/profile.php');
|
|
echo '</div>';
|
|
|
|
echo '</div>';
|
|
|
|
|
|
|
|
?>
|