ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 7602|回复: 11

[转帖]在PowerPoint中制作精确坐标系

[复制链接]

TA的精华主题

TA的得分主题

发表于 2004-9-8 14:10 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
实用技巧:在PowerPoint中制作精确坐标系
作者:沈艺  来源:《中国电脑教育报》  

在中学数学的课件制作中,坐标系是不可缺少的,特别是《解析几何》等方面的内容。可是,我们在PowerPoint中制作课件,坐标系通常是用线条组合而成的,很难做到量化上的精确。那么如何才能根据我们的需要灵活定制精确的坐标系呢?一起来看看吧。

参数面板的制作 首先在幻灯片编辑状态,点击菜单命令“视图→工具栏→控件工具箱”,打开“控件工具箱”工具栏,点击“文字框”控件。用鼠标拖放的方法在幻灯片编辑区拖放四个文字输入框,用“绘图”工具栏上的文本框工具给每一个文字输入框加上注释,最终效果如图1所示。其中前两个文字输入框分别接受坐标原点的横纵坐标(当然是相对于放映窗口左上角而言),而第三个文字输入框“单位”则是指画出的坐标系中每一小格的长度(以磅为单位),而“长度”则会接受每一个半轴所要画出的格数(也就是单位刻度的个数)。

图1 设定界面

这些内容完成后,再点击“控件工具箱”中的“命令按钮”控件,同样用鼠标拖放的办法在幻灯片编辑窗口拖放出三个命令按钮。

命令按钮的代码编辑 选中第一个命令按钮,点击右键,在弹出的快捷菜单中选择“属性”命令,打开其属性设置对话框,点击“Caption”右侧属性栏,将其内容改为“画坐标系”(如图2)。用同样的方法将另外两个命令按钮的“Caption”属性修改为“清空数据”和“清除图像”。

图2 设定按钮属性

TA的精华主题

TA的得分主题

 楼主| 发表于 2004-9-8 14:11 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

选中[画坐标系]命令按钮,点击右键,在弹出的快捷菜单中选择“查看代码”命令,打开“Microsoft Visual Basic”编辑窗口,找到这样两行代码:

Private Sub CommandButton1_Click()

End Sub

在它们之间插入如下代码:

h = Val(TextBox1.Text)

k = Val(TextBox2.Text)

Length = Val(TextBox3.Text)

Number = Val(TextBox4.Text)

Dim xx

xx = 1

Do While xx < Number

If xx Mod 5 = 0 Then

SlideShowWindows(1).View.DrawLine h + xx ? Length, k - 7, h + xx ? Length, k

SlideShowWindows(1).View.DrawLine h - xx ? Length, k - 7, h - xx ? Length, k

SlideShowWindows(1).View.DrawLine h, k - xx ? Length, h + 7, k - xx ? Length

SlideShowWindows(1).View.DrawLine h, k + xx ? Length, h + 7, k + xx ? Length

Else

SlideShowWindows(1).View.DrawLine h + xx ? Length, k - 3, h + xx ? Length, k

SlideShowWindows(1).View.DrawLine h - xx ? Length, k - 3, h - xx ? Length, k

SlideShowWindows(1).View.DrawLine h, k - xx ? Length, h + 3, k - xx ? Length

SlideShowWindows(1).View.DrawLine h, k + xx ? Length, h + 3, k + xx ? Length

End If

xx = xx + 1

Loop

SlideShowWindows(1).View.DrawLine h, k, h + xx ? Length, k

'画x轴正半轴

SlideShowWindows(1).View.DrawLine h - xx ? Length, k, h, k

'画x轴负半轴

SlideShowWindows(1).View.DrawLine h, k, h, k - xx ? Length

'画y轴正半轴

SlideShowWindows(1).View.DrawLine h, k, h, k + xx ? Length

'画y轴负半轴

选中[清空数据]命令按钮,仍用上面的方法打开它的代码编辑窗口,仍然找到这样两行代码:

Private Sub CommandButton2_Click()

End Sub

并在它们之间插入如下代码:

TextBox1.Value = ""

TextBox2.Value = ""

TextBox3.Value = ""

TextBox4.Value = ""

而那个[清除图像]按钮,在它的代码编辑窗口中输入如下代码:

Private Sub CommandButton3_Click()

SlideShowWindows(1).View.EraseDrawing

End Sub

实现效果 现在您就可以点击PowerPoint菜单命令“幻灯片放映→观看放映”观看制作效果了。在各个参数输入框中输入我们希望的数据,然后点击[画坐标系]命令按钮,一个精确的坐标系立即出现在我们的面前,图3所示即为实现效果。点击[清空数据]按钮和[清除图像]按钮,则会清除输入的数据或所画出的坐标系,可以重新进行设置。

图3 完成效果

TA的精华主题

TA的得分主题

 楼主| 发表于 2004-9-8 14:37 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
试验了一下,好像不行。不知道问题出在哪里。

TA的精华主题

TA的得分主题

发表于 2004-9-9 22:49 | 显示全部楼层

看着这么长的代码,晕........

有时间再来试一下.

TA的精华主题

TA的得分主题

发表于 2004-10-24 17:03 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2004-10-26 10:10 | 显示全部楼层

好是挺好的,就是太麻烦了吧,而且有什么实际作用吗?!我想不出.

TA的精华主题

TA的得分主题

发表于 2004-10-27 09:51 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

VBA在PPT中的应用~~

太棒了~~~~~

TA的精华主题

TA的得分主题

发表于 2004-10-27 11:42 | 显示全部楼层

Drawline语句后面的参数有问题。

我将 Length 去掉后能画出图像,却无法改变单位刻度大小。

4dPHpyOf.rar (15.64 KB, 下载次数: 109)

TA的精华主题

TA的得分主题

发表于 2004-10-31 15:28 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2008-9-15 07:54 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
太烦。看不下去了。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-23 21:09 , Processed in 0.038258 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表