User Tools

Site Tools


wargroundscanberra:character_sheet

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
wargroundscanberra:character_sheet [2024/07/18 18:06] curufeawargroundscanberra:character_sheet [2024/08/30 15:32] (current) curufea
Line 2: Line 2:
 ^  Go back to [[start|Wargrounds Canberra]]  ^ ^  Go back to [[start|Wargrounds Canberra]]  ^
  
-  * Working Form: [[form]]+ 
 +===== No Longer Used ===== 
 +This project has been superseded by NanDeck (makes it much easier). But I'll keep it on my website just because it was fun to do. 
 + 
 +==== Forms ==== 
 + 
 +  * Working Form: [[form|Fill in Character Sheet]]
   * Working Location: [[https://www.curufea.com/image.php]]    * Working Location: [[https://www.curufea.com/image.php]] 
-  * Testing Location: [[https://www.curufea.com/image_test.php]]+  * Test (same as working) 
 +    * Form: [[form test|Fill in Character Sheet]] 
 +    * Location: [[https://www.curufea.com/image_test.php]] 
 + 
 +==== Code ====
  
-<code>+<code php>
 <?php <?php
 // Character Sheet creator for Wargrounds Canberra // Character Sheet creator for Wargrounds Canberra
-// To be added- some images (to be sourced) as defaults - background, factions, space fillers and icons +// Version 1.5 20/8/24 - curufea@yahoo.com (character backgorunds)
-// To be added- a player photo (part of the form input) and basic text +
-// Version 0.3 16/7/24 - curufea@yahoo.com+
 // Currently hosted at www.curufea.com // Currently hosted at www.curufea.com
  
Line 17: Line 25:
 $font = 'blackwoodcastle.ttf'; // for field names $font = 'blackwoodcastle.ttf'; // for field names
 $font_data = 'oldeenglish.ttf'; // for player data $font_data = 'oldeenglish.ttf'; // for player data
 +$font_wargrounds = 'vinque_rg.otf'; // for the "W"
 // Path to images (relative to the location of this file) // Path to images (relative to the location of this file)
 $imagepath = 'data/media/wargroundscanberra/'; $imagepath = 'data/media/wargroundscanberra/';
-// Bacground image texture 
-$imageback = $imagepath.'another-rough-old-and-worn-parchment-paper.jpg'; 
-$im2 = imagecreatefromjpeg("$imageback"); 
  
-//defaults - to be overwritten by form inputs +// defaults for sizes - to be overwritten by form inputs 
-$fontsize = 20;+$tempwidth = round(intval($_GET["width"])); 
 +if (($tempwidth>0) and ($tempwidth<4000)) { 
 +    $width = $tempwidth; 
 +    } else { 
 +    $width = 530; // pixel size x of image 
 +    }; 
 +$height = round($width*1.422); // size y of image 
 +$fontsize = round($width/26.5);
 $linespacing = round($fontsize*2); $linespacing = round($fontsize*2);
-$width 530; // pixel size x of image +$borderwidth round($width/100); 
-$height 754// size y of image+$fontborder = round($borderwidth/2); 
 +$textlength 30;
  
-// array of default field names +// default placeholder photo to be replaced by image from form url 
-$names array( +$photo="https://www.worldhistory.org/uploads/images/15277.jpg"; 
-"Player Name:", +if (isset($_GET["photo"])) $photo=$_GET["photo"];
-"Character's Name:", +
-"Titles/Nicknames:", +
-"Race/Species:", +
-"Hair Colour:"+
-"Eye Colour:"+
-"Skin Colour:", +
-"Class & Tier:", +
-"School of Magic:", +
-"Faction:", +
-"Warband:", +
-"Marx:");+
  
-$factions_images array( +// the image used for the coin piles 
-"clans.jpg"+$coins=$imagepath."coinpiles.png";
-"empire.jpg", +
-"greyscales.jpg", +
-"horde.jpg", +
-"wardens.jpg"); +
-$factions_titles = array( +
-"The Clans", +
-"The Empire", +
-"Greyscales", +
-"The Horde", +
-"The Wardens");+
  
-// test data note will need some error checking in futureprobably warnings where field data is too long to fit +// the image used for the weapons space filler 
-$player_data = array ( +$weapons=$imagepath."weapons.png"; 
-"Peter", "Cousin Curufea", "", "Human (?)","Natural","Natural","Natural","Mage (Tier 3)","Divine Caster","3","Bone Hearts","0+ 
-);+ 
 +// array of default field names 
 +$names = array( 
 + "Player Name:", "Character's Name:", "Titles/Nicknames:", "Race/Species:",  "Class & Tier:", "School of Magic-""Faction:", "Warband:", "Marx:", "Fletching Colours-", "Character Background-"); 
 +// the field names used in the form 
 +$getnames = array( 
 + "name", "character", "title", "species", "class", "magic", "faction", "warband", "marx", "fletching", "background"); 
 +//    0                            3        4        5          6              8        9            10 
 +  
 +  
 +// 400px x 400px jpeg images stored on the image path (in the Dokuwiki media areafor faction logos 
 +$factions_images = array("greyscales.png", "clans.png", "empire.png", "horde.png", "wardens.png" ); 
 +// used to cross reference the form data to the image name (the Bureaucracy plugin for the Dokuwiki doesn't send selection number chosen) 
 +$factions_titles = array("Greyscales", "The Clans", "The Empire", "The Horde", "The Wardens"); 
 +// 2987px x 4250px jpeg images stored on the image path (in the Dokuwiki media area) for faction backgrounds 
 +$factions_backgrounds = array("2background.jpg", "0background.jpg", "1background.jpg", "3background.jpg","4background.jpg"); 
 +
   
 // count number of field names // count number of field names
 $numnames = count($names)-1; $numnames = count($names)-1;
 +
 +// As it is used multiple times, make the font border thingy a function
 +function DoFontBorder ($im,$font_size,$start_x,$start_y,$colour,$font,$text,$font_border) {
 + for ($x1=($start_x-$font_border);$x1<=($start_x+$font_border);$x1++) {
 + for ($y1=($start_y-$font_border);$y1<=($start_y+$font_border);$y1++) {
 +// imagettftext($im, $font_size, 0, $x1, $y1, $colour, $font, $text);
 + };
 + };
 +};
 +
 +// check if any variables have been sent to this image - if they have, overwrite the default player data
 +for ($count=0;$count<=$numnames;$count++) {
 +   $player_data[$count]= $_GET[$getnames[$count]];
 +   // Convert the text of the selection for faction to a number
 +   if ($count==6) {
 +    $player_data[$count]= array_search($_GET[$getnames[$count]],$factions_titles);
 +    $bgimage=$factions_backgrounds [$player_data[$count]];
 + };
 + };
 +
 +// Background image texture - now themed to faction
 +$imageback = $imagepath.$bgimage;
 +$im2 = imagecreatefromjpeg("$imageback");
  
 // Create image // Create image
Line 69: Line 101:
  
 // pick color for the text // pick color for the text
-$fontcolor = imagecolorallocate($image, 0, 0, 0);+$fontcolour = imagecolorallocate($image, 0, 0, 0); 
 + 
 +// pick color for text borders 
 +$bordercolour = imagecolorallocate($image, 255,255, 255);
  
 // add background texture // add background texture
Line 80: Line 115:
 $x = $fontsize;  $x = $fontsize; 
 $y = $fontsize; $y = $fontsize;
 +
 +$showstuff = true; // by default show all fields
 +
 +// Add weapons to the character Sheet if there's no character background
 +if (strlen($player_data[9])+strlen($player_data[10])==0) {
 + $im6 = imageCreateFromPng($weapons);
 + imagecopyresized($image,$im6, $linespacing*2, $linespacing*13,0,0,round($width/3.5),round($width/3), imagesx($im6), imagesy($im6));
 + imagedestroy($im6);
 +};
 +
 +// Add coin piles to the character Sheet
 +$im5 = imageCreateFromPng($coins);
 +if (strlen($player_data[7])>15) {  // Move the coin piles down to fit long warband names
 + imagecopyresized($image,$im5, round($width/2), $linespacing*7,0,0,round($width/2),round($width/8), imagesx($im5), imagesy($im5));
 + } else {
 + imagecopyresized($image,$im5, round($width/2), $linespacing*6,0,0,round($width/2),round($width/8), imagesx($im5), imagesy($im5));
 + };
 +imagedestroy($im5);
 +
 +// Add the large W
 +imagettftext($image, $fontsize*3, 0, round($width*0.8), round($width/6), $fontcolour, $font_wargrounds, "W");
 +
 for ($count=0;$count<=$numnames;$count++) { for ($count=0;$count<=$numnames;$count++) {
  $y=$y+$linespacing;  // increment by estimated line separation height  $y=$y+$linespacing;  // increment by estimated line separation height
   
-// Clunky bit to do positioning.  I'll just generate an array next time  +// Clunky bit to do positioning.   
- if ($count==3||$count==7) $y=$y+$linespacing;  // blank lines to separate + if ($count==3||$count==4) $y=$y+$linespacing;  // blank lines to separate 
- if ($count==9) { // right column+  
 + if ($count==6) { // right column
  $y= $linespacing*5;  $y= $linespacing*5;
  $x= round($width/2);  $x= round($width/2);
  };  };
- if ($count==$numnames) { // centre the last text in the right column+ if ($count==8) { // centre the last text in the right column
  $text = $names[$count] . " 999"; // add possible length   $text = $names[$count] . " 999"; // add possible length 
  $text_box = imagettfbbox($fontsize,0,$font,$text); // makes an array of co-ordinates for the text box  $text_box = imagettfbbox($fontsize,0,$font,$text); // makes an array of co-ordinates for the text box
Line 97: Line 155:
  $y=$y+$linespacing;  $y=$y+$linespacing;
  };  };
-// Field names in blackwood castle font  +  
- imagettftext($image, $fontsize, 0, $x$y, $fontcolor, $font, $names[$count]);+ if ($count==9) { // Do the new Fletching field 
 + $y=$fontsize+($linespacing*10);  
 + $x $fontsize;  
 + };  
 + 
 + if ($count==10) { // Do the new background field 
 + $y=$fontsize+($linespacing*12);  
 + $x = $fontsize;  
 + };  
 +
 // Player data in olde english font // Player data in olde english font
  $text_box = imagettfbbox($fontsize,0,$font,$names[$count]); // workout where the field name ends  $text_box = imagettfbbox($fontsize,0,$font,$names[$count]); // workout where the field name ends
  $text_width = $text_box[2]-$text_box[0]+round($fontsize/2);  $text_width = $text_box[2]-$text_box[0]+round($fontsize/2);
  $text = $player_data[$count];  $text = $player_data[$count];
 +
 +// Hide the magic, fletching and background fields if they aren't filled in
 + if (($count==5) and strlen($text)<1) $showstuff = false;
 + if (($count==9) and strlen($text)<1) $showstuff = false;
 + if (($count==10) and strlen($text)<1) $showstuff = false;
 +
 +// Do the border for the field names
 + if ($showstuff) DoFontBorder ($image,$fontsize,$x,$y,$bordercolour,$font,$names[$count],$fontborder);
 +
 +// Field names in blackwood castle font
 + if ($showstuff) imagettftext($image, $fontsize, 0, $x, $y, $fontcolour, $font, $names[$count]);
 +
 + if ($showstuff==false) $showstuff=true;
 +
 // Change the selected faction to readable text (and add faction logo) // Change the selected faction to readable text (and add faction logo)
- if ($count==9) {+ if ($count==6) {
  $text = $factions_titles[intval($player_data[$count])];  $text = $factions_titles[intval($player_data[$count])];
  $faction= $imagepath.$factions_images[intval($player_data[$count])];  $faction= $imagepath.$factions_images[intval($player_data[$count])];
- $im3 = imagecreatefromjpeg("$faction"); + $im3 = imageCreateFromPng($faction);  // Put in the faction logo 
- imagecopyresized($image, $im3, $width-80120, 0, 0, 5050,imagesx($im3), imagesy($im3));+ $ratio = imagesy($im3)/imagesx($im3); // Try to keep the logos in the same aspect ratio 
 + imagecopyresized($image,$im3, round($width*0.84)round($linespacing*2.3), 0, 0, round($width/8)round($width/8*$ratio),imagesx($im3), imagesy($im3));
  imagedestroy($im3);  imagedestroy($im3);
  };  };
 +
 // Print the data // Print the data
- imagettftext($image, $fontsize, 0, $x+$text_width, $y, $fontcolor, $font_data, $text);+ 
 +// Put titles, magic type, fletching and background on the next line so it fits  
 + if (($count==5) or ($count==9)or ($count==10)) { 
 + if ($count==10) { 
 + $maxlen=25; // when to go to the next line 
 + $shorter = explode(" ",$text); 
 + $currentlength=0; // running total of the line length 
 + $currentline=1; 
 + $currentword=0; 
 + $text=""; 
 + for ($wordcount=0;$wordcount<count($shorter);$wordcount++) { 
 + $currentlength=$currentlength+strlen($shorter[$wordcount]); 
 + $text=$text.$shorter[$wordcount]." "; 
 + if ($currentlength>$maxlen){ 
 + $currentlength=0; 
 + if ($currentline<12) { 
 + DoFontBorder ($image,round($fontsize*3/4),$x,$y+(round($linespacing/2)*$currentline),$bordercolour,$font_data,$text,$fontborder); 
 + imagettftext($image, round($fontsize*3/4), 0, $x, $y+(round($linespacing/2)*$currentline), $fontcolour, $font_data,$text); 
 + }; 
 + $text=""; 
 + $currentline++; 
 + }; 
 + }; 
 + } else { 
 + DoFontBorder ($image,$fontsize,$x,$y+$linespacing,$bordercolour,$font_data,$text,$fontborder); 
 + imagettftext($image, $fontsize, 0, $x, $y+$linespacing, $fontcolour, $font_data, $text); 
 + }; 
 + } else { 
 + if (($count==2) or ($count==4) or ($count==7)) { // make titles, class and background smaller to fit 
 + $maxlen=15; 
 + if ($count==2) $maxlen=25; 
 + if (strlen($text)>$maxlen) { // split long lines in two 
 + $string_break=stripos($text," ",$maxlen-3);  // look for the first space after the $maxlen-3 character 
 + if (strlen($text)>$maxlen*2) $text=substr($text,0,stripos($text,",",$maxlen*2));  // truncate ludicrously long strings 
 + DoFontBorder ($image,round($fontsize*3/4),$x+$text_width,$y,$bordercolour,$font_data,substr($text,0,$string_break),$fontborder); 
 + DoFontBorder ($image,round($fontsize*3/4),$x+$text_width-($text_width*($count==2)),$y+($linespacing/1.5),$bordercolour,$font_data,substr($text,$string_break-strlen($text)),$fontborder); 
 + imagettftext($image, round($fontsize*3/4), 0, $x+$text_width, $y, $fontcolour, $font_data,substr($text,0,$string_break)); 
 + imagettftext($image, round($fontsize*3/4), 0, $x+$text_width-($text_width*($count==2)), $y+($linespacing/1.5), $fontcolour, $font_data,substr($text,$string_break-strlen($text))); 
 + } else { 
 + DoFontBorder ($image,round($fontsize*3/4),$x+$text_width,$y,$bordercolour,$font_data,$text,$fontborder); 
 + imagettftext($image, round($fontsize*3/4), 0, $x+$text_width, $y, $fontcolour, $font_data, $text); 
 + }; 
 + } else { 
 + DoFontBorder ($image,$fontsize,$x+$text_width,$y,$bordercolour,$font_data,$text,$fontborder); 
 + imagettftext($image, $fontsize, 0, $x+$text_width, $y, $fontcolour, $font_data, $text); 
 + }; 
 + };
 }; };
 +
 +// Add the photo to the character Sheet
 +$im4 = imagecreatefromjpeg($photo);
 +$ratio = imagesy($im4)/imagesx($im4); // Try to keep the photo in the same aspect ratio
 +
 +$start_x=round($width/1.8);
 +$start_y= round($width/1.5);
 +
 +$i_width= round($width*0.4);
 +$i_height= round($i_width*$ratio);
 +
 +$end_x= $start_x+$i_width;
 +$end_y= $start_y+$i_height;
 +
 +
 +// Draw border
 +imagefilledrectangle($image,$start_x-$borderwidth,$start_y-$borderwidth,$end_x+$borderwidth,$end_y+$borderwidth, $fontcolour);
 +
 +// Resize and place in character Sheet
 +imagecopyresized($image, $im4, $start_x, $start_y, 0,0, $i_width, $i_height, imagesx($im4), imagesy($im4));
 +imagedestroy($im4);
  
 // tell the browser that the content is an image // tell the browser that the content is an image
Line 125: Line 275:
 </code> </code>
  
-===== To do ===== 
- 
-  * A [[form test]] with default text for field names prefilled (but not as complex as the one in this link) 
-  * Images for the various bits 
-  * Possibly API use for wherever photos get stored (or just upload them) - may need to edit photos to fit 
-  * Variable sheet size - just scale everything to whatever is needed. 
  
  
wargroundscanberra/character_sheet.1721351185.txt.gz · Last modified: 2024/07/18 18:06 by curufea