本文介绍通过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中的超链接的更多相关文章

  1. JavaWeb_day03_员工信息添加修改删除

    day03员工的添加,修改,删除 修改功能 思路 : 点击修改员工数据之后,跳转到单行文本,查询要修改的员工id的全部信息,主键id设置为readonly,其余的都可以修改, 修改之后,提交按钮,提交 ...

  2. Web 1三级联动 下拉框 2添加修改删除 弹框

    Web  三级联动 下拉框 using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...

  3. 打通前后端全栈开发node+vue进阶【课程学习系统项目实战详细讲解】(3):用户添加/修改/删除 vue表格组件 vue分页组件

    第三章 建议学习时间8小时      总项目预计10章 学习方式:详细阅读,并手动实现相关代码(如果没有node和vue基础,请学习前面的vue和node基础博客[共10章] 演示地址:后台:demo ...

  4. SpringBoot定时任务升级篇(动态添加修改删除定时任务)

    需求缘起:在发布了<Spring Boot定时任务升级篇>之后得到不少反馈,其中有一个反馈就是如何动态添加修改删除定时任务?那么我们一起看看具体怎么实现,先看下本节大纲: (1)思路说明: ...

  5. 【转】C#添加修改删除文件文件夹大全

    [转]C#添加修改删除文件文件夹大全 C#添加修改删除文件文件夹大全 StreamWriter sw = File.AppendText(Server.MapPath(".")+& ...

  6. Oracle的学习二:表管理(数据类型、创建/修改表、添加/修改/删除数据、数据查询)

    1.Oracle表的管理 表名和列名的命名规则: 必须以字母开头: 长度不能超过30个字符: 不能使用oracle的保留字: 只能使用如下字符:A-Z, a-z, 0-9, $, # 等. Oracl ...

  7. ORM简介 单表添加修改删除表记录

    ---------------------------------------------------------------目标既定,在学习和实践过程中无论遇到什么困难.曲折都不灰心丧气,不轻易改变 ...

  8. Git----02本地仓库进行文件添加&修改&删除&查看

    一.将新文件上传到本地仓库----使用小乌龟工具 1.1.将文件添加到暂存区 进入仓库目录,创建文件,添加暂存区     1.2.将文件添加到本地仓库 选中已经添加到暂存区的文件,进行提交 二.查看本 ...

  9. Android 查询 添加 修改 删除通讯录联系人示例

    1.AndroidManifest.xml中添加权限 <uses-permission android:name="android.permission.READ_CONTACTS&q ...

随机推荐

  1. python django 之 django自定制分页

    自定制的分页模块 #!/usr/bin/env python3 # V1.1 解决问题: # 1). p 参数 为 负数 与 p 参数查过总页数时报错的问题 # V1.2 解决的问题: # 1). 点 ...

  2. HttpClientFactory的套路,你知多少?

    背景 ASP.NET Core 在 2.1 之后推出了具有弹性 HTTP 请求能力的 HttpClient 工厂类 HttpClientFactory. 替换的初衷还是简单摆一下: ① using(v ...

  3. 一起了解 .Net Foundation 项目 No.12

    .Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. Cecil Cecil 是 ...

  4. sql04

    1.类型转换 ),ClassId)+name from [user]; 2.一次性插入多条数据 3.日期函数 1)getdate() 返回当前日期 2)dateadd 计算增加后的时间 ,'2020- ...

  5. SAP CRM Transaction处理中的权限控制

    当试图打开一个Opportunity时, 系统会进行如下一系列的权限检查: 1. 检查Authorization object CRM_ORD_OP: 此处会检查当前user的partner func ...

  6. jQuery上传文件按钮美化

    效果图如下: 思路: 1:打开文件设置为透明,外面包一层标签,给标签设置颜色背景,给人点击浏览其实是点击打开文件的错觉.(给外标签相对定位,打开文件标签绝对定位). 2:点击浏览后,选择了文件,就把文 ...

  7. vue的watch

    watch它可以用来监测Vue实例上的数据变动  尽量一张图解释清楚(尝试用圈圈区分关系): 写的很简单,watch本来就没啥东西我理解为响应式侦听全局变量 watch里绑定全局变量,被绑定全局变量发 ...

  8. Django中update和save()同时作用

    数据更新操作,对单条记录,可以使用save或者是update两种方式. save() 默认保存后会看到sql语句中更新了所有字段,而save的值是之前获取时候的字段值,是缓存下来的,并不一定最新,可能 ...

  9. vue+django+webpack搭建

    一.前言 最近接手了一个项目,后端是django,前端是django自带的模板,用的是jinja2,写了一段时间发现用起来特别不顺手,于是想在保持现有的模板基础上,引入vue框架,这样同事可以继续用自 ...

  10. git密令使用

    git密令是一种非常好用的代码版本管理工具,相比SVN,Sourcetree 使用起来复杂,主要是没有汉化包,当你使用熟练时,其实也是非常简单的,逼格高. 具体使用如下: 情景一:你只有远程库,没有本 ...