get SVG size
git-svn-id: file:///home/shish/svn/shimmie2/trunk@814 7f39781d-f577-437e-ae19-be835c7a54ca
This commit is contained in:
parent
62d0f3df7c
commit
cc3767c1b8
@ -14,10 +14,7 @@ class SVGFileHandler extends Extension {
|
|||||||
if(is_a($event, 'DataUploadEvent') && $this->supported_ext($event->type) && $this->check_contents($event->tmpname)) {
|
if(is_a($event, 'DataUploadEvent') && $this->supported_ext($event->type) && $this->check_contents($event->tmpname)) {
|
||||||
$hash = $event->hash;
|
$hash = $event->hash;
|
||||||
$ha = substr($hash, 0, 2);
|
$ha = substr($hash, 0, 2);
|
||||||
if(!copy($event->tmpname, "images/$ha/$hash")) {
|
if(!move_upload_to_archive($event)) return;
|
||||||
$event->veto("SVG Handler failed to move file from uploads to archive");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
send_event(new ThumbnailGenerationEvent($event->hash, $event->type));
|
send_event(new ThumbnailGenerationEvent($event->hash, $event->type));
|
||||||
$image = $this->create_image_from_data("images/$ha/$hash", $event->metadata);
|
$image = $this->create_image_from_data("images/$ha/$hash", $event->metadata);
|
||||||
if(is_null($image)) {
|
if(is_null($image)) {
|
||||||
@ -74,9 +71,9 @@ class SVGFileHandler extends Extension {
|
|||||||
|
|
||||||
$image = new Image();
|
$image = new Image();
|
||||||
|
|
||||||
// FIXME: ugh, xml parsing :|
|
$msp = new MiniSVGParser($filename);
|
||||||
$image->width = 0;
|
$image->width = $msp->width;
|
||||||
$image->height = 0;
|
$image->height = $msp->height;
|
||||||
|
|
||||||
$image->filesize = $metadata['size'];
|
$image->filesize = $metadata['size'];
|
||||||
$image->hash = $metadata['hash'];
|
$image->hash = $metadata['hash'];
|
||||||
@ -89,9 +86,33 @@ class SVGFileHandler extends Extension {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private function check_contents($file) {
|
private function check_contents($file) {
|
||||||
// FIXME: magic header?
|
if(!file_exists($file)) return false;
|
||||||
return (file_exists($file));
|
|
||||||
|
$msp = new MiniSVGParser($file);
|
||||||
|
return $msp->valid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class MiniSVGParser {
|
||||||
|
var $valid=false, $width=0, $height=0;
|
||||||
|
|
||||||
|
function MiniSVGParser($file) {
|
||||||
|
$xml_parser = xml_parser_create();
|
||||||
|
xml_set_element_handler($xml_parser, array($this, "startElement"), array($this, "endElement"));
|
||||||
|
$this->valid = xml_parse($xml_parser, file_get_contents($file), true);
|
||||||
|
xml_parser_free($xml_parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
function startElement($parser, $name, $attrs) {
|
||||||
|
if($name == "SVG") {
|
||||||
|
$this->width = int_escape($attrs["WIDTH"]);
|
||||||
|
$this->height = int_escape($attrs["HEIGHT"]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function endElement($parser, $name) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
add_event_listener(new SVGFileHandler());
|
add_event_listener(new SVGFileHandler());
|
||||||
?>
|
?>
|
||||||
|
@ -2,12 +2,11 @@
|
|||||||
|
|
||||||
class SVGFileHandlerTheme extends Themelet {
|
class SVGFileHandlerTheme extends Themelet {
|
||||||
public function display_image($page, $image) {
|
public function display_image($page, $image) {
|
||||||
$link = make_link("get_svg/{$image->id}/{$image->id}.svg");
|
$ilink = make_link("get_svg/{$image->id}/{$image->id}.svg");
|
||||||
$ilink = $image->get_image_link();
|
// $ilink = $image->get_image_link();
|
||||||
// FIXME: object and embed have "height" and "width"
|
|
||||||
$html = "
|
$html = "
|
||||||
<object data='$ilink' type='image/svg+xml' width='300' height='300'>
|
<object data='$ilink' type='image/svg+xml' width='{$image->width}' height='{$image->height}'>
|
||||||
<embed src='$ilink' type='image/svg+xml' width='300' height='300' />
|
<embed src='$ilink' type='image/svg+xml' width='{$image->width}' height='{$image->height}' />
|
||||||
</object>
|
</object>
|
||||||
";
|
";
|
||||||
$page->add_block(new Block("Image", $html, "main", 0));
|
$page->add_block(new Block("Image", $html, "main", 0));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user