Flex阅读器开发手册

Flex阅读器是一款由Devaldi开发的(Free)Flex程序库,它的功能是将服务器上的swf文件通过它生成的控件在浏览器上以类似PdfReader进行展示。可用它来制作精美的电子杂志和在线电子读物。


Flex阅读器安装及编程


  • 在(http://flexpaper.devaldi.com/)下载FlexPaper SWC,将FlexPaper_SDK4.swc拷贝到你的Flex项目libs中即可


  • 一个简单的例子,复制你的SWF到你的bin-debug目录,如man.swf,添加FlexPaper组件到你的flex代码中




  • Flex代码


  
   
   
   
   
  1. <?xml version="1.0" encoding="utf-8"?>
  2.  
  3. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
  4.  
  5. layout="absolute"
  6.  
  7. width="800" height="500"
  8.  
  9. xmlns:flexpaper="com.devaldi.controls.flexpaper.*">
  10.  
  11. <flexpaper:FlexPaperViewer width="800" height="500"
  12.  
  13. Scale="1" SwfFile="man.swf" />
  14.  
  15. </mx:Application>

 


  • 使用技巧

    (以下 mybook为FlexPaperViewer 的ID)

    除去打印控件图标

      在初始化组件事件处理函数中加入

                  mybook._FlexPaperViewer_GradientImageButton1.visible=false;

          也可以除去整个工具栏

                  mybook.removeElementAt(0);

    除去LOGO图标

          在初始化组件事件处理函数中且在文档加载处理函数中加入(removeElementAt(2)LOGO组件)

                 var A:Object=mybook.getChildAt(1);

                 A.removeElementAt(2);

           也可以写为(paper1为页面组件id):

                      mybook.paper1.removeElementAt(2);

    将工具栏的位置放入页面的底部

           在初始化组件事件处理函数中加入

                     mybook.removeElement(mybook.paper1);

                    mybook.addElementAt(mybook.paper1,0);

  • 参数: (以下参数可用于FlexPaper)


  • SwfFile(String)


打开Swf文件


  • Scale(Number)


放大因子,是一个0以上的数(带小数 1 = 100%) 。


  • ZoomTransition(String)


光学变焦过渡,默认值是easeOut,可取值: easenone, easeout, linear, easeoutquad


  • ZoomTime(Number)


时间过渡让变焦达到新的放大因子,值为0或更大的数。


  • ZoomInterval(Number)


区间的滑动缩放。放大因子缺省值是0.1。如同在工具栏上使用滑动条按钮的效果。


  • FitPageOnLoad(Boolean)


(布尔) 适合初始页大小(依高度而定)的装载页。如同在工具栏上使用fit-page按钮的效果。


  • FitWidthOnLoad(Boolean)


(布尔)适合初始页宽度大小的装载页。如同在工具栏上使用fit-width按钮的效果。


  • llocaleChain(String)


设置语言。

目前支持以下语言:

en_US(英语)

fr_FR(法国)

zh_CN(中国、简体)

es_ES(西班牙)

pt_BR(巴西葡萄牙语)

ru_RU(俄罗斯)

fi_FN芬兰

de_DE(德国)

nl_NL(荷兰)

tr_TR(土耳其)

se_SE(瑞典)

pt_PT(葡萄牙)

el_EL(希腊)

da_DN(丹麦)

cz_CS(捷克)

it_IT(意大利)

pl_PL(波兰)

pv_FN芬兰

hu_HU(匈牙利)


  • FullScreenAsMaxWindow(Boolean)


(布尔)以最大化方式打开一个新浏览器窗口。


  • ProgressiveLoading(Boolean)


(布尔) 将视本地负荷情况逐步地下载显示文档,而不是下载完后再显示。至少Flash9 以上版本的SWF生成文档


  • MaxZoomSize(Number)


(数值) 最大允许设置缩放等级


  • MinZoomSize(Number)


(数值) 允许设置最小缩放等级


  • SearchMatchAll(Boolean)


(布尔) 当被设置为真时,可执行搜索功能。


  • InitViewMode(String)


(字符串) 设置启动视图模式。例如“Portrait”或“TwoPage”。


  • ViewModeToolsVisible(Boolean)


(布尔)显示或隐藏视图模式与工具栏


  • ZoomToolsVisible(Boolean)


(布尔) 从工具栏显示或隐藏变焦工具


  • NavToolsVisible(Boolean)


(布尔)显示或隐藏导航工具


  • CursorToolsVisible(Boolean)


(布尔) 显示或隐藏光标工具


  • SearchToolsVisible(Boolean)


(布尔)显示或隐藏的搜索工具


  • 下面例子可以通过参数的使用预编译的flash版


  
   
   
   
   
  1. var fp = new FlexPaperViewer( 'FlexPaperViewer', 'viewerPlaceHolder', {
  2.  
  3. config : {
  4.  
  5. SwfFile : "Paper.swf",
  6.  
  7. Scale : 0.6,
  8.  
  9. ZoomTransition : "easeOut",
  10.  
  11. ZoomTime : 0.5,
  12.  
  13. ZoomInterval : 0.1,
  14.  
  15. FitPageOnLoad : false,
  16.  
  17. FitWidthOnLoad : false,
  18.  
  19. PrintEnabled : false,
  20.  
  21. FullScreenAsMaxWindow : true,
  22.  
  23. ProgressiveLoading : true,
  24.  
  25. MinZoomSize : 0.2,
  26.  
  27. MaxZoomSize : 5,
  28.  
  29. SearchMatchAll : false,
  30.  
  31. InitViewMode : 'Portrait',
  32.  
  33. ViewModeToolsVisible : true,
  34.  
  35. ZoomToolsVisible : true,
  36.  
  37. NavToolsVisible : true,
  38.  
  39. CursorToolsVisible : true,
  40.  
  41. SearchToolsVisible : true,
  42.  
  43. localeChain : "zh_CN" }});

  • 函数功能


  • .gotoPage(Number pageNumber)


定位到你指定的页面


  • .fitWidth()


适合宽度设置模式


  • .fitHeight()


适合高度模式


  • .loadSwf(String swffile)


载入一个新文件


  • .getCurrPage()


载入一个页为当前页


  • .nextPage()


下一页为当前页


  • .prevPage()


移动到前一页


  • .Zoom(Number factor)


变焦到指定的大小因子


  • .searchText(String text)


搜索指定的文本


  • .switchMode(String mode)


开启观赏模式。"Portrait", "Two Page", "Tile" // “肖像模式”、“两个页面”、“平铺


  • .printPaper()


文件打印


  • .highlight(String url)


高亮突出链接地址


  • .postSnapshot(String url)


网页“快照”文档指定的url



  • Events事件


  • onDocumentLoaded (no arguments)


文档完成装载时


  • onDocumentLoadedError (String errormessage)


文档完成装载错误发生时


  • onProgress (Number bytesloaded, Number bytestotal)


文档装载时的过程中(装入的字节)


  • onCurrentPageChanged (Number pagenumber)


当当前页面发生改变时


  • onExternalLinkClicked (String link)


当一个用户点击一个外部链接。

(Only works when supplying argument "-s linknameurl" in conversion with PDF2SWF)


  • onDocumentPrinted (no arguments)


当一个文件已完成打印时



服务器端的SWFTools


为了让PlexPaper能运行首先得要有SWF文件,而在服务器内常使用开源的SwfTools自动完成这种转换, SWFTools 是一组用来处理 Flash 的 swf文件的工具包,包括:

1. 合并工具 swfcombine

2. 抽取工具 swfextract

3. PDF/JPEG/PNG/AVI/TTF/WAV 到 SWF 的转换工具 :pdf2swf, jpeg2swf, png2swf, avi2swf, font2swf, and wav2swf|

4. 文本解析工具 swfstrings

5. SWF 解析器 swfdump

6. SWF 读写库 rfxswflib



  • 一个简单的将PDF文档转成SWF的用法:


windows C:\SWFTools\pdf2swf 源文件.pdf -o 目标文件.swf -f -T 9

linux /usr/local/bin/pdf2swf $pdfFile -o $swfFile -f -T 9 -t -s storeallcharacters > /dev/null


  • PDF2SWF转换文件参数


-h , --help 打印帮助短消息并退出

-V , --version 打印版本信息并退出

-o , --output file.swf 直接输出到文件。如果文件名为(file%.swf)输出每页为单独的文件。输出文件为:file[1-n].swf

-p , --pages range 仅转换中的页面范围与范围例如 1-20 or 1,4,6,9-11

-P , --password password 使用密码破译加密的pdf文件。

-v , --verbose 显示详细信息。

-z , --zlib 使用flash 6 MX压缩和解压缩。

-i , --ignore 允许pdf2swf更改pdf的绘制顺序。

-j , --jpegquality quality 设置嵌入jpeg图片的质量,以质量。 0质量最差,100质量最佳。缺省值:85

-s , --set param=value 设置SWF编码器的特定参数。

-w , --samewindow 在转换为pdf的超链接时,不让链接打开一个新窗口。

-t , --stop 在每页中插入停止命令。

-T , --flashversion num 设置Flash版本。

-F , --fontdir directory 添加到搜索字体的路径目录。

-b , --defaultviewer 添加到搜索路径的字体目录。

-l , --defaultloader 一个标准的预加载器swf文件的链接加载。

-B , --viewer filename 查看器文件名以swf文件的链接。

-L , --preloader filename 预加载器文件名以swf文件的链接。

-q , --quiet 取消正常的消息,也可使用-qq取消警告。

-S , --shapes 不使用SWF的字体,但一切都存储为形状。

-f , --fonts 存储完整的字体在SWF。不减少使用的字符。

-G , --flatten 尽可能从文件中删除尽可能多的剪贴图层。

-I , --info 不做实际的转换,只显示在PDF中所有页面的列表。

-Q , --maxtime n 在n秒后,中止转换。仅Unix可用。



  • 下面的4个常用的参数意义:


-f 字体应该嵌入,提高可检索的文档

-T 设定目标flash版到9,提高稳定性

-t 每一帧之间插入一个停止,提高稳定性

-s storeallcharacters 存储文档中的所有字符文本的信息,提高了可搜索性

 

可选参数:

-G14 使文件更小、更快的渲染

-s subpixels=1.5 subpixels = 1.5 在文档中调整图像分辨率。

在某些情况下应使用文件含有丰富的大的图像。

值(1.5),可以尝试要求质量档案。

请参阅http://wiki.swftools.org/index.php/Pdf2swfhttp://wiki.swftools.org/index.php/Pdf2swffor

一个完整的PDF2SWF例子。


 


  • Linux下源码编译安装 SwfTools


安装swftools 及其编译支持库(jpegsrc,freetype)

1.安装jpegsrc.v7.tar.gz

tar -zxvf jpegsrc.v7.tar.gz

cd jpeg-7

./configure

make

make install

2.安装freetype-2.3.12.tar.gz

tar -zxvf freetype-2.3.12.tar.gz

cd freetype-2.3.12

./configure

make

make install

3.安装swftools-2011-01-23-1815.tar.gz

tar -zxvf swftools-2011-01-23-1815.tar.gz

cd swftools-2011-01-23-1815

ldconfig /usr/local/lib

./configure

make

make install


编程实例


(以下的应用实例仅为参考,如要真正运行服务器端需要本人的写的flexsys_class 类库支持的运行环境)


  • XML定义文件: (sysbooks.xml)


  
   
   
   
   
  1. <?xml version="1.0" encoding="utf-8"?>
  2.  
  3. <root>
  4.  
  5. <title label="技术文档" key="">
  6.  
  7. <node label="服务器安装手册" key="serverMan.swf" pdfFile="服务器安装手册.pdf"/>
  8.  
  9. </title>
  10.  
  11. <title label="帮助文档" key="">
  12.  
  13. <node label="信贷档案操作说明" key="xdarMan.swf" pdfFile="信贷模块操作说明.pdf"/>
  14.  
  15. </title>
  16.  
  17. <title label="信贷资料" key="">
  18.  
  19. <node label="信贷资料管理系统实施方案" key="xdarMan1.swf" pdfFile="信贷资料管理系统实施方案.pdf"/>
  20.  
  21. </title>
  22.  
  23. </root>

  • 客户端程序: (sysbooks.mxml)


  
   
   
   
   
  1. <?xml version="1.0" encoding="utf-8"?>
  2.  
  3. <mx:Module xmlns:fx="http://ns.adobe.com/mxml/2009"
  4.  
  5. xmlns:s="library://ns.adobe.com/flex/spark"
  6.  
  7. xmlns:mx="library://ns.adobe.com/flex/mx"
  8.  
  9. layout="absolute" width="100%" height="100%"
  10.  
  11. mouseMove="vrule1_mouseMoveHandler(event)"
  12.  
  13. mouseUp="vrule1_mouseUpHandler(event)"
  14.  
  15. xmlns:flexpaper="com.devaldi.controls.flexpaper.*"
  16.  
  17. creationComplete="initApp()">
  18.  
  19. <fx:Style source="flex_root.css" />
  20.  
  21. <fx:Script>
  22.  
  23. <![CDATA[
  24.  
  25. import mx.collections.*;
  26.  
  27. import mx.controls.Alert;
  28.  
  29. import mx.events.DragEvent;
  30.  
  31. import mx.events.ListEvent;
  32.  
  33. import mx.managers.CursorManager;
  34.  
  35. import mx.rpc.events.FaultEvent;
  36.  
  37. import mx.rpc.events.ResultEvent;
  38.  
  39. import mylib.*;
  40.  
  41. public var Ocookies:MyCookies;
  42.  
  43. [Bindable]
  44.  
  45. public var http_server:String;
  46.  
  47. [Bindable]
  48.  
  49. private var userKey:String;
  50.  
  51. [Bindable]
  52.  
  53. private var xmldoc:XML;
  54.  
  55. [Embed(source="images/resizeCursorH.gif")]
  56.  
  57. public var Movecus:Class;
  58.  
  59. private var cursorID:int;
  60.  
  61. private var moveCursorFlag:Boolean=false;
  62.  
  63. public var pdf_filename:String="";
  64.  
  65. public function initApp():void {
  66.  
  67. Ocookies=this.parentApplication.Ocookies;
  68.  
  69. http_server=Ocookies.ServerAddr;
  70.  
  71. userKey=Ocookies.UserInfo.user_key;
  72.  
  73. search_xml.send();
  74.  
  75. //除去打印控件图标
  76.  
  77. mybook._FlexPaperViewer_GradientImageButton1.visible=false;
  78.  
  79. //也可以除去整个工具栏
  80.  
  81. mybook.removeElementAt(0);
  82.  
  83. //除去LOGO图标
  84.  
  85. var A:Object=mybook.getChildAt(1);
  86.  
  87. A.removeElementAt(2);
  88.  
  89. }
  90.  
  91. //Cursor控制---------------------------------------------------------
  92.  
  93. protected function vrule1_mouseOverHandler(event:MouseEvent):void{
  94.  
  95. cursorID = CursorManager.setCursor(Movecus,2,-10,-10);
  96.  
  97. }
  98.  
  99. protected function vrule1_mouseOutHandler(event:MouseEvent):void{
  100.  
  101. CursorManager.removeCursor(cursorID);
  102.  
  103. }
  104.  
  105. protected function vrule1_mouseDownHandler(event:MouseEvent):void{
  106.  
  107. moveCursorFlag=true;
  108.  
  109. }
  110.  
  111. protected function vrule1_mouseUpHandler(event:MouseEvent):void{
  112.  
  113. moveCursorFlag=false;
  114.  
  115. }
  116.  
  117. protected function vrule1_mouseMoveHandler(event:MouseEvent):void{
  118.  
  119. if(!moveCursorFlag) return;
  120.  
  121. myTree.width=event.stageX - 5;
  122.  
  123. if(myTree.width<100){
  124.  
  125. myTree.width=100;
  126.  
  127. moveCursorFlag=false;
  128.  
  129. }
  130.  
  131. if(myTree.width>500) myTree.width=500;
  132.  
  133. }
  134.  
  135. //---------------------------------------------------------Cursor控制
  136.  
  137. public function handleFault(event:FaultEvent):void{
  138.  
  139. Alert.show(event.fault.faultString , "通信错误");
  140.  
  141. }
  142.  
  143. //装入
  144.  
  145. public function fsearch_xml(event:ResultEvent):void{
  146.  
  147. xmldoc=XML(event.result);
  148.  
  149. myTree.validateNow();
  150.  
  151. for each(var item:XML in myTree.dataProvider) myTree.expandChildrenOf(item,true);
  152.  
  153. }
  154.  
  155. protected function myTree_changeHandler(event:ListEvent):void{
  156.  
  157. var data:Object=myTree.selectedItem;
  158.  
  159. var sFile:String=data.@key;
  160.  
  161. if(sFile!=""){
  162.  
  163. var pdfFile:String=data.@pdfFile;
  164.  
  165. var sGet:String="?pdfFile="+pdfFile+"&swfFile="+sFile;
  166.  
  167. mybook.SwfFile=http_server+"/flex_root/PHP/sys/getHelpPDF.php"+sGet;
  168.  
  169. }
  170.  
  171. //除去LOGO图标
  172.  
  173. var A:Object=mybook.getChildAt(1);
  174.  
  175. A.removeElementAt(2);
  176.  
  177. }
  178.  
  179. ]]>
  180.  
  181. </fx:Script>
  182.  
  183. <fx:Declarations>
  184.  
  185. <mx:HTTPService id="search_xml"
  186.  
  187. url="{http_server}/flex_root/PHP/sys/sysbooks.xml"
  188.  
  189. method="POST"
  190.  
  191. showBusyCursor="true"
  192.  
  193. result="fsearch_xml(event)"
  194.  
  195. fault="handleFault(event)"
  196.  
  197. resultFormat="e4x">
  198.  
  199. </mx:HTTPService>
  200.  
  201. </fx:Declarations>
  202.  
  203. <s:HGroup width="100%" height="100%" gap="0" x="0" y="0">
  204.  
  205. <mx:Tree id="myTree" width="180" height="100%"
  206.  
  207. dataProvider="{xmldoc.title}" labelField="@label" change="myTree_changeHandler(event)">
  208.  
  209. </mx:Tree>
  210.  
  211. <mx:VRule height="100%" tabEnabled="true"
  212.  
  213. mouseOver="vrule1_mouseOverHandler(event)"
  214.  
  215. mouseOut="vrule1_mouseOutHandler(event)"
  216.  
  217. mouseDown="vrule1_mouseDownHandler(event)" />
  218.  
  219. <s:BorderContainer width="100%" height="100%" backgroundColor="#cccccc">
  220.  
  221. <flexpaper:FlexPaperViewer id="mybook" width="100%" height="100%" FitPageOnLoad="true"
  222.  
  223. Scale="1" SwfFile="" />
  224.  
  225. </s:BorderContainer>
  226.  
  227. </s:HGroup>
  228.  
  229. </mx:Module>

  • 服务器端程序: (getHelpPDF.php)


  
   
   
   
   
  1. <?php
  2.  
  3. //获得PDF文件至swf文件的转换
  4.  
  5. function __autoload($class_name) {
  6.  
  7. require_once($class_name . '.php');
  8.  
  9. }
  10.  
  11. $oSYS=new flexsys_class();
  12.  
  13. $SysDataPath=$oSYS->BASE_data;
  14.  
  15. $name=iconv("utf-8","gb2312//IGNORE",$_GET["pdfFile"]);
  16.  
  17. $pdfFile=$SysDataPath."/pubftp/help/".$name;
  18.  
  19. $swfFile=$SysDataPath."/pubftp/help/".$_GET["swfFile"];
  20.  
  21. if(!file_exists($pdfFile)) exit;
  22.  
  23. $pdfTime=filemtime($pdfFile);
  24.  
  25. if(!file_exists($swfFile)){
  26.  
  27. $swfTime=0;
  28.  
  29. }else{
  30.  
  31. $swfTime=filemtime($swfFile);
  32.  
  33. }
  34.  
  35. if($pdfTime > $swfTime){
  36.  
  37. if(PHP_OS=="Linux"){
  38.  
  39. @system("/usr/local/bin/pdf2swf $pdfFile -o $swfFile -f -T 9 -t -s storeallcharacters > /dev/null");
  40.  
  41. }else{
  42.  
  43. @system('"c:/usr/web_root/pdf2swf.exe" $pdfFile -o $swfFile -f -T 9 -t -s storeallcharacters');
  44.  
  45. }
  46.  
  47. }
  48.  
  49. echo $oSYS->downWebFile($swfFile);
  50.  
  51. ?>

flexpaper 参数说明

Publish: February 8, 2012 Category: PHP,FlexPaper No Comments

 

Flexpaper可能用到如下参数


   SwfFile (String) 需要使用Flexpaper打开的文档
   Scale (Number) 初始化缩放比例,参数值应该是大于零的整数
   ZoomTransition (String) Flexpaper中缩放样式,它使用和Tweener一样的样式,默认参数值为easeOut.其他可选值包括: easenone, easeout, linear, easeoutquad
   ZoomTime (Number) 从一个缩放比例变为另外一个缩放比例需要花费的时间,该参数值应该为0或更大。
   ZoomInterval (Number) 缩放比例之间间隔,默认值为0.1,该值为正数。
   FitPageOnLoad (Boolean) 初始化得时候自适应页面,与使用工具栏上的适应页面按钮同样的效果。
   FitWidthOnLoad (Boolean) 初始化的时候自适应页面宽度,与工具栏上的适应宽度按钮同样的效果。
   localeChain (String) 设置地区(语言),目前支持以下语言。

en_US (English) 
fr_FR (French) 
zh_CN (Chinese, Simple) 
es_ES (Spanish) 
pt_BR (Brazilian Portugese) 
ru_RU (Russian) 
fi_FN (Finnish) 
de_DE (German) 
nl_NL (Netherlands) 
tr_TR (Turkish) 
se_SE (Swedish) 
pt_PT (Portugese) 
el_EL (Greek) 
da_DN (Danish) 
cz_CS (Czech) 
it_IT (Italian) 
pl_PL (Polish) 
pv_FN (Finnish) 
hu_HU (Hungarian)
   FullScreenAsMaxWindow (Boolean) 当设置为true的时候,单击全屏按钮会打开一个flexpaper最大化的新窗口而不是全屏,当由于flash播放器因为安全而禁止全屏,而使用flexpaper作为独立的flash播放器的时候设置为true是个优先选择。
   ProgressiveLoading (Boolean) 当设置为true的时候,展示文档时不会加载完整个文档,而是逐步加载,但是需要将文档转化为9以上的flash版本(使用pdf2swf的时候使用-T 9 标签)。
   MaxZoomSize (Number) 设置最大的缩放比例。
   MinZoomSize (Number) 最小的缩放比例。
   SearchMatchAll (Boolean) 设置为true的时候,单击搜索所有符合条件的地方高亮显示。
   InitViewMode (String) 设置启动模式如"Portrait" or "TwoPage".
   ViewModeToolsVisible (Boolean) 工具栏上是否显示样式选择框。
   ZoomToolsVisible (Boolean) 工具栏上是否显示缩放工具。
   NavToolsVisible (Boolean) 工具栏上是否显示导航工具。
   CursorToolsVisible (Boolean) 工具栏上是否显示光标工具。
  

SearchToolsVisible (Boolean)

工具栏上是否显示搜索。

你可能感兴趣的:(Flex阅读器开发手册)