最近有大量的资料需要阅读,常常用到Adobe Reader8.0阅览器。不过最让人头疼的就是这个阅览器没有添加书签的功能。如果遇到上百页的文本,自己下次阅读的时候还需要自己再重复寻找上次的阅读终点,那么有没有在Adobe Reader8.0阅览器中添加书签的方法呢?最近通过摸索和网络求助,找到了一个简单快捷的方法在Adobe Reader8.0阅览器中添加书签。
具体步骤如下:
第一步,下载一个“PDF支持书签的修改程序源文件”。地址为“http://download.csdn.net/source/362724”(如果你能链接则将全部复制到地址栏回车即可)。
第二步,将下载的文件重命名为“bookmark_page.js”.
第三步,将bookmark_page.js文件复制到“计算机/C:/Program Files/Adobe/Reader8.0/Reader/Javascripts/”(我的计算机是Vista系统,如果是XP系统的话将文件复制到 C:/Program Files/Adobe/Reader8.0/Reader/Javascripts/即可)。
第四步,重新启动Reader8.0,你会在视图选项的下拉菜单中看到有设置本页为书签、转到指定书签、删除一个书签和删除所以书签选项,这样你就可以添加书签了!
注:如果下载不了,可以用下载代码复制另存为bookmark_page.js即可.
// bookmark_page.js, ver. 1.0
// visit: www.pdfhacks.com/bookmark_page/
// edit:cjs 2008-02-17
// 1 修改为中文标签
// 2 设置书签时可以自动获取当前的书名
// 3 自动获取当前所在的页码与总页数,方便查阅
// 4 实现更多功能可以参看Adobe Reader的SDK
// use this delimiter for serializing our array
var bp_delim= '%#%#';
function SaveData( data ) {
// data is an array of arrays that needs
// to be serialized and stored into a persistent
// global string
var ds= '';
for( ii= 0; ii< data.length; ++ii ) {
for( jj= 0; jj< 3; ++jj ) {
if( ii!= 0 || jj!= 0 )
ds+= bp_delim;
ds+= data[ii][jj];
}
}
global.pdf_hacks_js_bookmarks= ds;
global.setPersistent( "pdf_hacks_js_bookmarks", true );
}
function GetData() {
// reverse of SaveData; return an array of arrays
if( global.pdf_hacks_js_bookmarks== null ) {
return new Array(0);
}
var flat= global.pdf_hacks_js_bookmarks.split( bp_delim );
var data= new Array();
for( ii= 0; ii< flat.length; ) {
var record= new Array();
for( jj= 0; jj< 3 && ii< flat.length; ++ii, ++jj ) {
record.push( flat[ii] );
}
if( record.length== 3 ) {
data.push( record );
}
}
return data;
}
//Get Current Date
function DateNow(){
var d, s ;
d = new Date();
s = d.getFullYear()+"/";
s += (d.getMonth() + 1) + "/";
s += d.getDate() ;
/*
s += d.getHours() + ":";
s += d.getMinutes() + ":";
s += d.getSeconds() ;
*/
return(s);
}
function AddBookmark() {
// query the user for a name, and then combine it with
// the current PDF page to create a record; store this record
var thisfilename=this.documentFileName;
thisfilename=thisfilename.substr(0,thisfilename.lastIndexOf("."));
var numPlugInss=this.pageNum+1;
var currentdate=DateNow();
var label=
app.response( "书签名称,可以修改以便于记忆:",
"书签名称",
"《"+thisfilename+"》第 "+numPlugInss+" 页/共 "+this.numPages+" 页 "+currentdate,
false );
if( label!= null ) {
var record= new Array(3);
record[0]= label;
record[1]= this.path;
record[2]= this.pageNum;
data= GetData();
data.push( record );
SaveData( data );
}
}
function ShowBookmarks() {
// show a pop-up menu; this seems to only work when
// a PDF is alreay in the viewer;
var data= GetData();
var items= '';
for( ii= 0; ii< data.length; ++ii ) {
if( ii!= 0 )
items+= ', ';
items+= '"'+ ii+ ': '+ data[ii][0]+ '"';
}
// assemble the command and the execute it with eval()
var command= 'app.popUpMenu( '+ items+ ' );';
var selection= eval( command );
if( selection== null ) {
return; // exit
}
// the user made a selection; parse out its index and use it
// to access the bookmark record
var index= 0;
// toString() converts the String object to a string literal
// eval() converts the string literal to a number
index= eval( selection.substring( 0, selection.indexOf(':') ).toString() );
if( index< data.length ) {
try {
// the document must be 'disclosed' for us to have any access
// to its properties, so we use these FirstPage NextPage calls
//
app.openDoc( data[index][1] );
app.execMenuItem( "FirstPage" );
for( ii= 0; ii< data[index][2]; ++ii ) {
app.execMenuItem( "NextPage" );
}
}
catch( ee ) {
var response=
app.alert("打开书签错误. 是否删除本书签?", 2, 2,"删除书签");
if( response== 4 && index< data.length ) {
data.splice( index, 1 );
SaveData( data );
}
}
}
}
function DropBookmark() {
// modelled after ShowBookmarks()
var data= GetData();
var items= '';
for( ii= 0; ii< data.length; ++ii ) {
if( ii!= 0 )
items+= ', ';
items+= '"'+ ii+ ': '+ data[ii][0]+ '"';
}
var command= 'app.popUpMenu( '+ items+ ' );';
var selection= eval( command );
if( selection== null ) {
return; // exit
}
var index= 0;
index= eval( selection.substring( 0, selection.indexOf(':') ).toString() );
if( index< data.length ) {
data.splice( index, 1 );
SaveData( data );
}
}
function ClearBookmarks() {
if( app.alert("确认要清除所有的书签吗?", 2, 2,"删除书签" )== 4 ) {
SaveData( new Array(0) );
}
}
app.addMenuItem( {
cName: "-", // menu divider
cParent: "View", // append to the View menu
cExec: "void(0);" } );
app.addMenuItem( {
cName: "设置本页为书签(&B)",
cParent: "View",
cExec: "AddBookmark();",
cEnable: "event.rc= (event.target != null);" } );
app.addMenuItem( {
cName: "转到指定书签(&T)",
cParent: "View",
cExec: "ShowBookmarks();",
cEnable: "event.rc= (event.target != null);" } );
//cEnable: "event.rc= true;" } );
app.addMenuItem( {
cName: "删除一个书签(&D)",
cParent: "View",
cExec: "DropBookmark();",
cEnable: "event.rc= (event.target != null);" } );
app.addMenuItem( {
cName: "清除所有书签(&C)",
cParent: "View",
cExec: "ClearBookmarks();",
cEnable: "event.rc= true;" } );
分享到:
相关推荐
JavaScript PDF阅读器是一种基于Web的解决方案,它允许用户在浏览器中直接查看PDF文档,而无需安装额外的软件或插件。这种技术对于提供方便、快速的在线服务特别有用,尤其适用于那些希望在网页上分享文档但又不希望...
5. **交互功能**:JavaScript PDF阅读器通常还提供诸如缩放、书签、高亮、注释等交互功能。这些功能通过监听用户的鼠标和键盘事件,调用PDF.js提供的API来实现。 6. **性能优化**:由于PDF文件可能很大,PDF.js会...
在IT领域,特别是软件开发中,VC++ PDF阅读器是一个重要的工具,用于在Windows环境中查看和处理PDF(Portable Document Format)文件。PDF是一种普遍使用的文件格式,它能保持文档的原始布局和样式,使得信息交流...
虽然这个示例是针对Adobe Reader 8.0的,但类似的逻辑可以应用于其他支持JavaScript的PDF阅读器,只需适应不同版本的API和用户界面。通过这种方式,你可以根据自己的需求定制PDF阅读环境,使得阅读和导航大型文档变...
在PDF阅读器中,JavaScript常被用来增强交互性和功能性,比如实现动态书签的添加、删除和修改。这个脚本可能定义了与书签操作相关的函数和逻辑,如监听用户的交互事件,更新书签列表,以及在PDF文档中定位书签所指向...
在本主题中,我们将深入探讨“简单实用的PDF阅读器”的相关知识点。 1. PDF文件的基本概念:PDF是一种由Adobe Systems公司开发的文件格式,它能够准确地保留原始文档的格式和内容,包括字体、图像和布局。这种格式...
在iOS平台上,开发一款PDF阅读器是一个常见的需求,特别是在Xcode 4.4及更高版本中,开发者可以利用内置的WebKit框架和UIWebView组件来实现这一功能。UIWebView是iOS SDK提供的一种轻量级的浏览器控件,它可以加载并...
3. **交互功能**:一个完整的PDF阅读器可能还需要提供一些交互功能,如缩放、平移、书签、搜索、高亮等。这些功能可以通过JavaScript在前端实现,与后端C#服务进行交互,获取必要的PDF信息。 4. **安全性**:处理...
9. **跨平台兼容性**:由于不同的浏览器和PDF阅读器可能对JavaScript的支持程度不同,开发者需要考虑兼容性问题,确保代码能在多种环境下正常工作。 10. **性能优化**:处理PDF文件可能涉及大量的计算和资源消耗,...
在Web开发中,PDF查看器插件对于那些需要在网站上展示PDF内容的开发者来说至关重要,例如在线文档共享、电子书阅读平台等。jQuery和JavaScript是两种常用的前端开发语言,它们能够提供动态和交互性的用户体验。 ...
HTML5网页PDF查看器是一种基于Web技术实现的PDF文档预览和阅读工具,它允许用户在浏览器中直接打开和查看PDF文件,而无需依赖任何桌面应用程序。这种技术的出现极大地提升了网页的交互性和用户体验,特别是在处理...
4. 用户交互:在线阅读器需要提供类似于本地PDF阅读器的功能,如缩放、翻页、搜索、书签等。这些功能可以通过JavaScript实现,与后端服务配合完成。 三、实例代码分析 在"PDFView_Web"这个项目中,我们可以看到...
2. **阅读器功能**:基本的PDF阅读器提供浏览、搜索、放大缩小、旋转页面、书签管理等功能。高级阅读器可能还包括注释工具(如高亮、划线、添加文字)、表单填写、数字签名、页面组织等。 3. **Adobe Acrobat ...
在uniapp中预览PDF,我们需要一个PDF阅读器组件或者服务。尽管uniapp本身并不直接支持PDF预览,但我们可以借助第三方库或插件来实现这一功能。 一种常见的方式是使用HTML5的`<iframe>`标签或者Web组件来嵌入PDF文件...
7. **安全性**:考虑到PDF文件可能包含恶意代码,JavaFX PDF阅读器还需要实现安全机制,防止执行潜在的危险操作,例如防止JavaScript执行或者限制不安全的链接点击。 8. **用户体验**:优秀的PDF阅读器不仅要能正确...
以下是对PDF阅读器及其相关知识点的详细解释: 1. **PDF的起源与特性** - PDF最初由Adobe Systems开发,旨在解决电子文档在不同平台间的兼容性问题。 - PDF文件可以包含文本、图像、超链接、表格、图形、注释、...
迷你版PDF阅读器是一款小巧而实用的软件工具,专为那些希望在不占用大量系统资源的情况下,轻松查看PDF文档的用户设计。与市面上常见的大型PDF阅读器相比,它以其轻便、快速和简洁的界面赢得了用户的青睐。这款阅读...
通过结合使用PDF.js,开发者可以创建一个具有高级特性的PDF阅读器,比如平滑滚动、双页视图、文本选择和书签。 在手机网页上,考虑到移动设备的性能和屏幕大小,优化用户体验尤为重要。这可能包括适配不同的屏幕...
2. UI设计:PDF阅读器的界面设计包括页面导航、缩放、旋转、书签、搜索等功能。这些功能的实现需要对Android的UI组件有深入理解,如RecyclerView用于展示书签,GestureDetector和ScaleGestureDetector用于捕捉用户的...