ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[已解决] 如何将图表网格线间距设置成正方形

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-7-18 19:50 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 Finstar 于 2024-7-19 11:03 编辑

EXCEL_3N445jgfLW.png


如上图所示,为了使图形不向右图那样失真
希望能将X,Y轴网格间距约束成等距,如左图红框为正方形

我目前是手动拉伸,近视为正方形
能否设置成正方形,拉伸图形等比放大?

还请大侠指导,谢谢了!

TA的精华主题

TA的得分主题

发表于 2024-7-18 20:18 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-7-18 21:51 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
捕获.PNG

不适用于折线图等

Sub ScalePlot()
On Error Resume Next
    Rem ---- 修正图表绘图区为最大方正化
    Dim Cht As Chart, Ser As Series, AxX As Axis, AxY As Axis
    Dim XVals, YVals, MinX, MinY, MaxX, MaxY
    Dim i
    Dim PWd, PHt, PWd1, PHt1
    Dim XDiff, YDiff, XDiff1, YDiff1
    Dim Buffer
    Dim WdScale, HtScale
    Set Cht = ActiveChart
    Rem ---- 遍历所有系列确定MinX,MinY,MaxX,MaxY
    With Cht
        For i = 1 To Cht.SeriesCollection.Count
            Set Ser = Cht.SeriesCollection(i)
            XVals = Ser.XValues
            YVals = Ser.Values
            If i = 1 Then
                MinX = Application.Min(XVals)
                MaxX = Application.Max(XVals)
                MinY = Application.Min(YVals)
                MaxY = Application.Max(YVals)
            Else
                MinX = Application.Min(MinX, XVals)
                MaxX = Application.Max(MaxX, XVals)
                MinY = Application.Min(MinY, YVals)
                MaxY = Application.Max(MaxY, YVals)
            End If
        Next
        Rem ---- 最大化绘图区域并获取其尺寸
        With .PlotArea
            .Top = 0
            .Left = 0
            .Width = Cht.ChartArea.Width
            .Height = Cht.ChartArea.Height
            PWd = .Width
            PHt = .Height
            PWd1 = .InsideWidth
            PHt1 = .InsideHeight
        End With
        Set AxX = .Axes(xlCategory)
        Set AxY = .Axes(xlValue)
        Rem ---- X和Y值的范围
        XDiff = MaxX - MinX
        YDiff = MaxY - MinY
        Rem ---- 对XDiff和YDiff设置10%的缓冲空间,以便在系列边缘和绘图区之间有空白
        Buffer = 0.1
        Rem ---- 调整Max/MinX/Y的值
        MaxX = MaxX + Buffer * XDiff
        MinX = MinX - Buffer * XDiff
        MaxY = MaxY + Buffer * YDiff
        MinY = MinY - Buffer * YDiff
        Rem ---- 修正X和Y值的范围
        XDiff = MaxX - MinX
        YDiff = MaxY - MinY
        Rem ---- 重新缩放坐标轴以获得最大可能的放大倍率
        With AxX
            .MaximumScale = MaxX
            .MinimumScale = MinX
        End With
        With AxY
            .MaximumScale = MaxY
            .MinimumScale = MinY
        End With
        Rem ----计算绘图区单位X和Y的比例
        WdScale = PWd1 / XDiff
        HtScale = PHt1 / YDiff
        If WdScale > HtScale Then
            Rem ----X轴需要调整
            Rem ----保持Y轴比例不变
            XDiff1 = (XDiff * WdScale / HtScale - XDiff) / 2
            AxX.MinimumScale = MinX - XDiff1
            AxX.MaximumScale = MaxX + XDiff1
        Else
            Rem ----Y轴需要调整
            Rem ----保持X轴比例不变
            YDiff1 = (YDiff * HtScale / WdScale - YDiff) / 2
            AxY.MinimumScale = MinY - YDiff1
            AxY.MaximumScale = MaxY + YDiff1
        End If
    End With
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-19 09:22 | 显示全部楼层
wb_1027 发表于 2024-7-18 21:51
不适用于折线图等

Sub ScalePlot()

谢谢大侠,成功约束成等距了。
另外,能否把网格坐标圆整成个位数为0或5的整数?
EXCEL_EsQFLW17go.png

TA的精华主题

TA的得分主题

发表于 2024-7-19 10:54 | 显示全部楼层
Finstar 发表于 2024-7-19 09:22
谢谢大侠,成功约束成等距了。
另外,能否把网格坐标圆整成个位数为0或5的整数?

1721357548964.png


这个其实没什么必要使用代码,手动调一下就行了,,,

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-19 11:03 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
wb_1027 发表于 2024-7-19 10:54
这个其实没什么必要使用代码,手动调一下就行了,,,

好的,谢谢大侠!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-9-8 08:23 , Processed in 0.044516 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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