-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgenerateSetImages.php
65 lines (45 loc) · 1.54 KB
/
generateSetImages.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
<?php
$TABLE_SUFFIX = "45";
$OUTPUT_PATH = "/home/uesp/esoItemImages/sets/";
require("itemLinkImage.class.php");
if ($TABLE_SUFFIX == "")
$OUTPUT_PATH .= GetEsoUpdateVersion() . "/";
else
$OUTPUT_PATH .= "$TABLE_SUFFIX/";
print("Generating all set image tooltips for update $TABLE_SUFFIX to '$OUTPUT_PATH'...\n");
if (!file_exists($OUTPUT_PATH) && !mkdir($OUTPUT_PATH, 0775, true)) exit("Error: Failed to create directory '$OUTPUT_PATH'!");
$itemLinkImage = new CEsoItemLinkImage();
$itemLinkImage->version = $TABLE_SUFFIX;
$db = new mysqli($uespEsoLogReadDBHost, $uespEsoLogReadUser, $uespEsoLogReadPW, $uespEsoLogDatabase);
if ($db->connect_error) exit("Could not connect to mysql database!");
$query = "SELECT * FROM setSummary$TABLE_SUFFIX ORDER BY setName;";
$result = $db->query($query);
if ($result === false) die("Failed to load set records!\n");
$sets = [];
while ($row = $result->fetch_assoc())
{
$sets[] = $row;
}
$count = count($sets);
print("Loaded $count sets for update $TABLE_SUFFIX!\n");
$sumTime = 0;
$successCount = 0;
foreach ($sets as $set)
{
$setName = $set['setName'];
$startTime = microtime(true);
$image = $itemLinkImage->CreateSetImage($setName);
$sumTime += microtime(true) - $startTime;
if ($image)
{
$filename = $OUTPUT_PATH . $setName . ".png";
imagepng($image, $filename);
print("\tSaved $setName to '$filename'\n");
++$successCount;
}
}
if ($count > 0)
{
$avgTime = ($sumTime / $count * 1000);
print("Saved $successCount set image tooltips with an average generation time of $avgTime ms.\n");
}