C# 添加、修改、删除PPT中的超链接
本文介绍通过C# 编程如何在PPT幻灯片中添加超链接的方法,添加链接时,可给文本或者图片添加超链接,链接对象可指向网页地址、邮件地址、指定幻灯片等,此外,也可以参考文中编辑、删除幻灯片中已有超链接的方法。
程序使用类库:Free Spire.Presentation for .NET (免费版)
dll获取及引用:
方法1:可通过官网下载包,解压将Bin文件夹下的程序安装到指定路径;完成安装后,将安装路径下Bin文件夹中的Spire.Presentation.dll文件添加引用到程序,并添加using指令。
方法2:可通过Nuget安装导入。
Dll添加引用效果如下图:
C# 代码示例
1. 添加超链接到PPT幻灯片
using Spire.Presentation;
using Spire.Presentation.Drawing;
using System.Drawing; namespace AddHyperlink
{
class Program
{
static void Main(string[] args)
{
//初始化Presentation实例
Presentation ppt = new Presentation(); //添加一张幻灯片作为第二张幻灯片(创建文档时,已默认生成一页幻灯片)
ppt.Slides.Append(); //获取第1张幻灯片,并添加形状
ISlide slide1 = ppt.Slides[];
IAutoShape shape = slide1.Shapes.AppendShape(ShapeType.Rectangle, new RectangleF(, , ,));
shape.Fill.FillType = FillFormatType.Solid;
shape.Fill.SolidColor.Color = Color.LightYellow;
shape.ShapeStyle.LineColor.Color = Color.White; //声明字符串变量
string s1 = "BIDU";
string s2 = "是全球最大的中文搜索引擎,中国最大的以信息和知识为核心的互联网综合服务公司,全球领先的人工智能平台型公司。";
string s3 = "详见第二页内容介绍"; //获取形状段落(默认有一个空白段落)
TextParagraph paragraph = shape.TextFrame.TextRange.Paragraph;
paragraph.Alignment = TextAlignmentType.Left; //根据字符串s1创建tr1,并在文字上添加链接,指向网页地址
TextRange tr1 = new TextRange(s1);
tr1.ClickAction.Address = "https://www.baidu.com/";
//tr1.ClickAction.Address = "mailto:123654zz@163.com";//指向邮件地址 //根据字s2创建tr2
TextRange tr2 = new TextRange(s2); //根据字符串s3创建tr3,并在文字上添加链接,指向第二张幻灯片
TextRange tr3 = new TextRange(s3);
ClickHyperlink link = new ClickHyperlink(ppt.Slides[]);
tr3.ClickAction = link; //将TextRange添加到段落
paragraph.TextRanges.Append(tr1);
paragraph.TextRanges.Append(tr2);
paragraph.TextRanges.Append(tr3); //设置段落的字体样式
foreach (TextRange tr in paragraph.TextRanges)
{
tr.LatinFont = new TextFont("宋体 (Body)");
tr.FontHeight = 20f;
tr.IsBold = TriState.True;
tr.Fill.FillType = FillFormatType.Solid;
tr.Fill.SolidColor.Color = Color.Black;
} //获取第2张幻灯片,添加形状,并将图片添加到形状,设置链接,指向网页地址
ISlide slide2 = ppt.Slides[];
RectangleF rect = new RectangleF(, , , );
IEmbedImage image = slide2.Shapes.AppendEmbedImage(ShapeType.Rectangle, @"tp.png", rect);
ClickHyperlink hyperlink = new ClickHyperlink("https://www.baidu.com/");
image.Click = hyperlink; //保存文档
ppt.SaveToFile("AddHyperlink.pptx", FileFormat.Pptx2010);
System.Diagnostics.Process.Start("AddHyperlink.pptx");
}
}
}
可在幻灯片放映中查看超链接添加效果。
文本超链接添加效果:
图片超链接添加效果:
2. 编辑、删除PPT幻灯片中的超链接
using Spire.Presentation; namespace ModifyHyperlink
{
class Program
{
static void Main(string[] args)
{
//初始化Presentation实例
Presentation ppt = new Presentation(); //加载现有的文档
ppt.LoadFromFile("AddHyperlink.pptx"); //获取第一张幻灯片
ISlide slide = ppt.Slides[]; //遍历shape
foreach (IShape shape in slide.Shapes)
{
//判断是否为autoshape
if (shape is IAutoShape)
{
//将shape转换为autoshape
IAutoShape autoShape = shape as IAutoShape; //遍历autoshape中的paragraph
foreach (TextParagraph tp in autoShape.TextFrame.Paragraphs)
{
//判断paragraph下是否含有textrange
if (tp.TextRanges != null && tp.TextRanges.Count > )
{
//遍历textrange
for (int tpcount = ; tpcount < tp.TextRanges.Count; tpcount++)
{
//判断是否含有文本且含有ClickAction和链接
if (tp.TextRanges[tpcount].ClickAction != null && !string.IsNullOrWhiteSpace(tp.TextRanges[tpcount].ClickAction.Address) && !string.IsNullOrWhiteSpace(tp.TextRanges[tpcount].Text))
{
//判断是否含有http链接或https链接
if (tp.TextRanges[tpcount].ClickAction.Address.ToLower().Contains("http") || tp.TextRanges[tpcount].ClickAction.Address.ToLower().Contains("https"))
{
//为链接重新赋值
tp.TextRanges[tpcount].ClickAction.Address = "https://baike.baidu.com/"; //重新设置超链接文本
tp.TextRanges[tpcount].Text = "百度百科"; //删除超链接
//tp.TextRanges[tpcount].ClickAction = null;
}
}
}
}
} } } //保存文档
ppt.SaveToFile("ModifyHyperlink.pptx", FileFormat.Pptx2010);
System.Diagnostics.Process.Start("ModifyHyperlink.pptx");
}
}
}
超链接修改结果:
超链接删除效果:
(本文完)
C# 添加、修改、删除PPT中的超链接的更多相关文章
- JavaWeb_day03_员工信息添加修改删除
day03员工的添加,修改,删除 修改功能 思路 : 点击修改员工数据之后,跳转到单行文本,查询要修改的员工id的全部信息,主键id设置为readonly,其余的都可以修改, 修改之后,提交按钮,提交 ...
- Web 1三级联动 下拉框 2添加修改删除 弹框
Web 三级联动 下拉框 using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...
- 打通前后端全栈开发node+vue进阶【课程学习系统项目实战详细讲解】(3):用户添加/修改/删除 vue表格组件 vue分页组件
第三章 建议学习时间8小时 总项目预计10章 学习方式:详细阅读,并手动实现相关代码(如果没有node和vue基础,请学习前面的vue和node基础博客[共10章] 演示地址:后台:demo ...
- SpringBoot定时任务升级篇(动态添加修改删除定时任务)
需求缘起:在发布了<Spring Boot定时任务升级篇>之后得到不少反馈,其中有一个反馈就是如何动态添加修改删除定时任务?那么我们一起看看具体怎么实现,先看下本节大纲: (1)思路说明: ...
- 【转】C#添加修改删除文件文件夹大全
[转]C#添加修改删除文件文件夹大全 C#添加修改删除文件文件夹大全 StreamWriter sw = File.AppendText(Server.MapPath(".")+& ...
- Oracle的学习二:表管理(数据类型、创建/修改表、添加/修改/删除数据、数据查询)
1.Oracle表的管理 表名和列名的命名规则: 必须以字母开头: 长度不能超过30个字符: 不能使用oracle的保留字: 只能使用如下字符:A-Z, a-z, 0-9, $, # 等. Oracl ...
- ORM简介 单表添加修改删除表记录
---------------------------------------------------------------目标既定,在学习和实践过程中无论遇到什么困难.曲折都不灰心丧气,不轻易改变 ...
- Git----02本地仓库进行文件添加&修改&删除&查看
一.将新文件上传到本地仓库----使用小乌龟工具 1.1.将文件添加到暂存区 进入仓库目录,创建文件,添加暂存区 1.2.将文件添加到本地仓库 选中已经添加到暂存区的文件,进行提交 二.查看本 ...
- Android 查询 添加 修改 删除通讯录联系人示例
1.AndroidManifest.xml中添加权限 <uses-permission android:name="android.permission.READ_CONTACTS&q ...
随机推荐
- windows下用Python把pdf文件转化为图片
依赖:PyMuPDF(pip install pymupdf) # -*- coding: utf-8 -*- """ 1.安装库 pip install pymupdf ...
- grid实战之微信钱包 腾讯服务界面
网格布局简介 CSS3网格布局是让开发人员设计一个网格并将内容放在这些网格内.而不是使用浮动制作一个网格,实际上是你将一个元素声明为一个网格容器,并把元素内容置于网格中. 有一些浏览器是不支持网格布局 ...
- 原生js中的常用方法的写法
1.js深度克隆的方法 //第一种 function deepClone(obj){ var str,newObj = obj instanceof Array? [] : {}; if(typeof ...
- 整合Kafka+Flink 实例(第二部分 设计思路)
前 言 拖了蛮久了,一直说要接着上一部分写设计思路以及代码,因为自己技术底子薄弱,加上人又懒,所以一直没能继续,今天补上设计思路及部分代码,后面有时间我会再补充一些应用性的功能,的确有些忙,希 ...
- jQuery上传文件按钮美化
效果图如下: 思路: 1:打开文件设置为透明,外面包一层标签,给标签设置颜色背景,给人点击浏览其实是点击打开文件的错觉.(给外标签相对定位,打开文件标签绝对定位). 2:点击浏览后,选择了文件,就把文 ...
- vuex和localStorage,全局变量的区别
vuex是状态管理,是为了解决跨组件之间数据共享问题的,一个组件的数据变化会映射到使用这个数据的其他组件当中.如果刷新页面,之前存储的vuex数据全部都会被初始化掉. localStorage是H5提 ...
- Redis集群搭建及选举原理
redis集群简述 哨兵模式中如果主从中master宕机了,是通过哨兵来选举出新的master,在这个选举切换主从的过程,整个redis服务是不可用的.而且哨兵模式中只有一个主节点对外提供服务,因此没 ...
- MVC超链接调用控制器内的方法
<a href="hello/Layout?name=Tom"><h1><span>Hello</span>World</h1 ...
- (转)windows宿主机,ubuntu虚拟机下的上网设置(有线网络和无线网络)
转自:http://hi.baidu.com/puppywst/item/d9f73734856e2af32684f4e3 虚拟机下ubuntu共享方式上网: 有线网络 在有线网络的条件下,vmwar ...
- Ansible Ad-Hoc与常用模块
ansible 执行结果信息–各颜色说明:ansible Ad-Hoc 说明:ansible 如何查看帮助文档与常用模块详解 主机规划 添加用户账号 说明: 1. 运维人员使用的登录账号: 2. 所有 ...