Image map image preview creator.
More...
|
| __construct ($imagemap_filename="") |
| ilImagemapPreview constructor More...
|
|
| getAreaCount () |
|
| getPointCount () |
|
| addArea ( $index, $shape, $coords, $title="", $href="", $target="", $visible=true, $linecolor="red", $bordercolor="white", $fillcolor="#FFFFFFA0") |
|
| addPoint ( $index, $coords, $visible=true, $linecolor="red", $bordercolor="white", $fillcolor="#FFFFFFA0") |
|
| getAreaIdent () |
|
| createPreview () |
|
| getPreviewFilename ($imagePath, $baseFileName) |
|
| getImagemap ($title) |
| get imagemap html code note: html code should be placed in template files More...
|
|
Image map image preview creator.
Takes an image and imagemap areas and creates a preview image containing the imagemap areas.
- Author
- Helmut Schottmüller helmu.nosp@m.t.sc.nosp@m.hottm.nosp@m.uell.nosp@m.er@ma.nosp@m.c.co.nosp@m.m
- Version
- $Id$
Definition at line 16 of file class.ilImagemapPreview.php.
◆ __construct()
ilImagemapPreview::__construct |
( |
|
$imagemap_filename = "" | ) |
|
ilImagemapPreview constructor
Creates an instance of the ilImagemapPreview class
- Parameters
-
integer | $id | The database id of a image map question object public |
Definition at line 34 of file class.ilImagemapPreview.php.
References $DIC, $imagemap_filename, $lng, $preview_filename, and ilUtil\ilTempnam().
41 if (!@is_file($this->preview_filename)) {
43 if (preg_match(
"/.*\.(png|jpg|gif|jpeg)$/", $this->imagemap_filename, $matches)) {
44 $extension =
"." . $matches[1];
46 include_once
"./Services/Utilities/classes/class.ilUtil.php";
49 $this->areas = array();
50 $this->points = array();
51 $this->linewidth_outer = 4;
52 $this->linewidth_inner = 2;
static ilTempnam($a_temp_path=null)
Returns a unique and non existing Path for e temporary file or directory.
◆ addArea()
ilImagemapPreview::addArea |
( |
|
$index, |
|
|
|
$shape, |
|
|
|
$coords, |
|
|
|
$title = "" , |
|
|
|
$href = "" , |
|
|
|
$target = "" , |
|
|
|
$visible = true , |
|
|
|
$linecolor = "red" , |
|
|
|
$bordercolor = "white" , |
|
|
|
$fillcolor = "#FFFFFFA0" |
|
) |
| |
Definition at line 65 of file class.ilImagemapPreview.php.
References $index.
77 if (ini_get(
"safe_mode")) {
78 if ((strpos($fillcolor,
"#") !==
false) || Â (strpos($fillcolor,
"rgb") !==
false)) {
79 $fillcolor = str_replace(
"\"",
"", $fillcolor);
82 $this->areas[
$index] = array(
84 "coords" =>
"$coords",
87 "target" =>
"$target",
88 "linecolor" =>
'"' . $linecolor .
'"',
89 "fillcolor" =>
'"' . $fillcolor .
'"',
90 "bordercolor" =>
'"' . $bordercolor .
'"',
91 "visible" => (
int) $visible
◆ addPoint()
ilImagemapPreview::addPoint |
( |
|
$index, |
|
|
|
$coords, |
|
|
|
$visible = true , |
|
|
|
$linecolor = "red" , |
|
|
|
$bordercolor = "white" , |
|
|
|
$fillcolor = "#FFFFFFA0" |
|
) |
| |
Definition at line 95 of file class.ilImagemapPreview.php.
References $index.
103 $this->points[
$index] = array(
104 "coords" =>
"$coords",
105 "linecolor" =>
'"' . $linecolor .
'"',
106 "fillcolor" =>
'"' . $fillcolor .
'"',
107 "bordercolor" =>
'"' . $bordercolor .
'"',
108 "visible" => (
int) $visible
◆ createPreview()
ilImagemapPreview::createPreview |
( |
| ) |
|
Definition at line 128 of file class.ilImagemapPreview.php.
References $i, $r, $source, $target, $x, $y, ilUtil\escapeShellCmd(), and ilUtil\execConvert().
130 if (count($this->areas) + count($this->points) == 0) {
133 include_once
"./Services/Utilities/classes/class.ilUtil.php";
134 $convert_cmd =
"-quality 100 ";
135 foreach ($this->points as $point) {
136 if ($point[
"visible"]) {
137 preg_match(
"/(\d+)\s*,\s*(\d+)/", $point[
"coords"], $matches);
142 $convert_cmd .=
"-stroke " . $point[
"bordercolor"] .
" -fill " . $point[
"fillcolor"] .
" -strokewidth $this->linewidth_outer -draw \"line " .
144 "-stroke " . $point[
"bordercolor"] .
" -fill " . $point[
"fillcolor"] .
" -strokewidth $this->linewidth_outer -draw \"line " .
146 "-stroke " . $point[
"linecolor"] .
" -fill " . $point[
"fillcolor"] .
" -strokewidth $this->linewidth_inner -draw \"line " .
148 "-stroke " . $point[
"linecolor"] .
" -fill " . $point[
"fillcolor"] .
" -strokewidth $this->linewidth_inner -draw \"line " .
152 foreach ($this->areas as $area) {
153 if ($area[
"visible"]
and strcmp(strtolower($area[
"shape"]),
"rect") == 0) {
154 preg_match(
"/(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)/", $area[
"coords"], $matches);
160 $convert_cmd .=
"-stroke " . $area[
"bordercolor"] .
" -fill " . $area[
"fillcolor"] .
" -strokewidth $this->linewidth_outer -draw \"rectangle " .
161 $x0 .
"," . $y0 .
" " . ($x1) .
"," . $y1 .
"\" " .
162 "-stroke " . $area[
"linecolor"] .
" -fill " . $area[
"fillcolor"] .
" -strokewidth $this->linewidth_inner -draw \"rectangle " .
163 $x0 .
"," . $y0 .
" " . ($x1) .
"," . $y1 .
"\" ";
164 } elseif ($area[
"visible"]
and strcmp(strtolower($area[
"shape"]),
"circle") == 0) {
165 preg_match(
"/(\d+)\s*,\s*(\d+)\s*,\s*(\d+)/", $area[
"coords"], $matches);
170 $convert_cmd .=
"-stroke " . $area[
"bordercolor"] .
" -fill " . $area[
"fillcolor"] .
" -strokewidth $this->linewidth_outer -draw \"circle " .
171 $x .
"," .
$y .
" " . (
$x +
$r) .
"," .
$y .
"\" " .
172 "-stroke " . $area[
"linecolor"] .
" -fill " . $area[
"fillcolor"] .
" -strokewidth $this->linewidth_inner -draw \"circle " .
173 $x .
"," .
$y .
" " . (
$x +
$r) .
"," .
$y .
"\" ";
174 } elseif ($area[
"visible"]
and strcmp(strtolower($area[
"shape"]),
"poly") == 0) {
177 preg_match_all(
"/(\d+)\s*,\s*(\d+)/", $area[
"coords"], $matches, PREG_PATTERN_ORDER);
178 if (count($matches[0]) == 2) {
181 $convert_cmd .=
"-stroke " . $area[
"bordercolor"] .
" -fill " . $area[
"fillcolor"] .
" -strokewidth $this->linewidth_outer -draw \"$obj ";
182 for (
$i = 0;
$i < count($matches[0]);
$i++) {
183 $convert_cmd .= $matches[1][
$i] .
"," . $matches[2][
$i] .
" ";
185 $convert_cmd .=
"\" ";
186 $convert_cmd .=
"-stroke " . $area[
"linecolor"] .
" -fill " . $area[
"fillcolor"] .
" -strokewidth $this->linewidth_inner -draw \"$obj ";
187 preg_match_all(
"/(\d+)\s*,\s*(\d+)/", $area[
"coords"], $matches, PREG_PATTERN_ORDER);
188 for (
$i = 0;
$i < count($matches[0]);
$i++) {
189 $convert_cmd .= $matches[1][
$i] .
"," . $matches[2][
$i] .
" ";
191 $convert_cmd .=
"\" ";
static escapeShellCmd($a_arg)
escape shell cmd
static execConvert($args)
execute convert command
◆ getAreaCount()
ilImagemapPreview::getAreaCount |
( |
| ) |
|
◆ getAreaIdent()
ilImagemapPreview::getAreaIdent |
( |
| ) |
|
Definition at line 112 of file class.ilImagemapPreview.php.
Referenced by getPreviewFilename().
114 if (count($this->areas) + count($this->points) > 0) {
115 $arr = array_merge(array_keys($this->areas), array_keys($this->points));
116 sort($arr, SORT_NUMERIC);
118 $inner = join(
"_", $arr);
119 if (strlen($inner) > 32) {
120 $inner = md5($inner);
122 return "preview_" . $inner .
"_";
◆ getImagemap()
ilImagemapPreview::getImagemap |
( |
|
$title | ) |
|
get imagemap html code note: html code should be placed in template files
Definition at line 231 of file class.ilImagemapPreview.php.
References $map.
233 $map =
"<map name=\"$title\"> ";
234 foreach ($this->areas as $area) {
235 $map .=
"<area alt=\"" . $area[
"title"] .
"\" title=\"" . $area[
"title"] .
"\" ";
236 $map .=
"shape=\"" . $area[
"shape"] .
"\" ";
237 $map .=
"coords=\"" . $area[
"coords"] .
"\" ";
239 $map .=
"href=\"" . $area[
"href"] .
"\" ";
240 if ($area[
"target"]) {
241 $map .=
"target=\"" . $area[
"target"] .
"\" ";
245 $map .=
"nohref />\n";
◆ getPointCount()
ilImagemapPreview::getPointCount |
( |
| ) |
|
◆ getPreviewFilename()
ilImagemapPreview::getPreviewFilename |
( |
|
$imagePath, |
|
|
|
$baseFileName |
|
) |
| |
Definition at line 201 of file class.ilImagemapPreview.php.
References $filename, $preview_filename, getAreaIdent(), and ilUtil\sendInfo().
204 if (count($this->areas) + count($this->points) > 0) {
206 if (is_file($pfile)) {
208 $previewfile = $imagePath . $ident . $baseFileName;
209 if (@md5_file($previewfile) != @md5_file($pfile)) {
210 if (strlen($ident) > 0) {
211 @copy($pfile, $previewfile);
215 if (strlen($pfile) == 0) {
static sendInfo($a_info="", $a_keep=false)
Send Info Message to Screen.
◆ $areas
ilImagemapPreview::$areas |
◆ $imagemap_filename
ilImagemapPreview::$imagemap_filename |
◆ $linewidth_inner
ilImagemapPreview::$linewidth_inner |
◆ $linewidth_outer
ilImagemapPreview::$linewidth_outer |
◆ $lng
◆ $points
ilImagemapPreview::$points |
◆ $preview_filename
ilImagemapPreview::$preview_filename |
The documentation for this class was generated from the following file: