Dokuwiki Image Plugin
도쿠위키에 그림을 넣으려면
{{http://img33.imageshack.us/img33/6457/lightboxindokuwiki.jpg}}
이렇게 중괄호에 그림의 주소를 넣으면 된다.
그런데 내용이 그림이더라도 확장자가 JPEG, PNG 같은 것이 아니면 (PHP 로 형성되는 실시간 그림이나 티스토리처럼 그냥 해쉬코드만 있는 경우) 그냥 파일로 인식되고 그림으로 표시되지 않는다.
도쿠위키에서는 파일이름의 끝에 &.jpg?
이런 것을 추가하라는데…1)
{{http://cfile7.uf.tistory.com/image/21117A3651126AAA2F2636&.jpg?}}
안되거든요? Gohr 아저씨?
되는 사이트도 있지만 안되는 사이트가 태반이다. 2)
그래서 간단한 플러긴을 만들어 보았다.
그냥
{{image>http://img33.imageshack.us/img33/6457/lightboxindokuwiki.jpg}} {{image>http://cfile7.uf.tistory.com/image/21117A3651126AAA2F2636}}
이런식으로 쓰면 파일이름에 관계없이 그냥 그림으로 표시한다. 아직 크기조절 기능은 없다.
http://img33.imageshack.us/img33/6457/lightboxindokuwiki.jpg http://cfile7.uf.tistory.com/image/21117A3651126AAA2F2636
- show.php
<?php /** * DokuWiki Plugin image (Syntax Component) * * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html * @author SC YOO <[email protected]> */ // must be run within Dokuwiki if (!defined('DOKU_INC')) die(); if (!defined('DOKU_LF')) define('DOKU_LF', "\n"); if (!defined('DOKU_TAB')) define('DOKU_TAB', "\t"); if (!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/'); require_once DOKU_PLUGIN.'syntax.php'; class syntax_plugin_image_show extends DokuWiki_Syntax_Plugin { public function getType() { return 'substition'; } public function getPType() { return 'normal'; } public function getSort() { return 301; } public function connectTo($mode) { $this->Lexer->addSpecialPattern('\{\{image>[^}]*\}\}',$mode,'plugin_image_show'); // $this->Lexer->addEntryPattern('<FIXME>',$mode,'plugin_image_show'); } // public function postConnect() { // $this->Lexer->addExitPattern('</FIXME>','plugin_image_show'); // } public function handle($match, $state, $pos, &$handler){ $data = array(); $match = substr($match,8,-2); //strip markup from start and end // alignment $data['align'] = 0; if(substr($match,0,1) == ' ') $data['align'] += 1; if(substr($match,-1,1) == ' ') $data['align'] += 2; $data['src']=$match; $data['class']='media '; return $data; } public function render ($mode, &$renderer, $data) { if($mode != 'xhtml') return false; switch ($data['align']){ case 1: $data['class'].="medialeft";break; case 2: $data['class'].="mediaright";break; case 3: $data['class'].="mediacenter";break; } $renderer->doc.= '<a href="'.$data['src'].'" rel="lightbox"><img src="'.$data['src'].'" class="'.$data['class'].'"></a>'; return true; } } // vim:ts=4:sw=4:et:
누구나 수정하실 수 있습니다. 위키 사용법 참고하세요. |
---|