微信公众号:XrayStudio
关注可了解更多的分享内容, 问题或建议,请公众号留言
版权申明
本文首发自微信公共账号:XrayStudio;
无需授权即可转载,可保留版权声明;
转载时请务必注明作者。
什么是正确方式?
初次接触Grasshopper 和 GhPython(Grasshopper中的python电池) 都给我难以名状的惊喜,随着使用的深入和了解的更多,就开始发现很多局限和不足。比如,在编辑器编写程序时括号得每个敲出来,无法自动补全编写不便,查看代码得打开Rhino_GH使用麻烦,函数不能跨电池调用复用性差等。
我的配置中使用VSCode(一款开源免费的轻量级代码编辑器)外部编辑器编写python代码,使用pythonstubs实现GHPytho函数查找并自动补全,这样就可以解决之前提到的和未提到的几乎所有编程问题。
简单概括在VSCode中编写GhPython的优点:可读性强
易于管理
方便查看
复用性强
姿态优美的方式便是正解。
环境配置Windows10
Rhino6
VSCode
Python3
pythonstubs
以上为我的配置,win7以上系统+Rhino5以上版本预计也可以;
Mac系统下没测试,应该类似。
具体步骤:Rhino安装不详述,希望支持正版;
VSCode安装:浏览器搜索 ---> 官网下载最新版 ---> 一路下一步即可;
pythonstubs安装:
WinKey (键盘左下四个方块) + r ,输入cmd 后回车,打开终端;
输入安装的命令回车安装,一般只输入第一条,第二条自动完成,两个都输入也没问题.
1pip install Rhino-stubs
2pip install Grasshopper-stubs
安装完成后会显示成功安装的提示,由于我已经安装,显示already satisfied
安装完成后,打开VSCode,新建文件,保存为 youFileName.py 这样的文件(.py文件),然后导入各个模块
1import Rhino
2import rhinoscriptsyntax as rs # Not Succeed
逐个调用,发现部分支持,其他几个主要使用的没法使用,在两台电脑多次测试未果。突然想起之前使用code-listener(也是一种文章核心问题的解决方式,个人不喜欢,大家可自行测试选择)时配置过路径,方式应该类似,经过不断测试,有了以下结果:
在GhPython中输入:
1import sys
2print sys.path
结果如下:
结果和自己的配置有关,和图中不一致很正常,关键的是紫色框中的那条'C:\\Users\\Dell\\AppData\\Roaming\\McNeel\\Rhinoceros\\6.0\\Plug-ins\\IronPython (814d908a-e25c-493d-97e9-ee3861957f49)\\settings\\lib'
选择复制所有,VSCode中新建文件并粘贴,将和紫色框中类似那条单独复制
在VSCode界面 Ctrl+, 打开设置界面,搜索栏输入extra paths
点击下方的 Edit in settings.json, 把之前复制的那句粘贴在大括号中:
注意要放在双引号中,路径层级间通过双反斜杠\\分隔开,然后保存,关闭并重启VSCode然后新建一个.py文件,即可步入编码高速路,效果如下:
使用方式
一般有两种使用方式:GH中调用三个电池:Path-Read File(Total File)-GHPython(右键-show "code input parameter),通过gh中三个组件的组合完成,在外部编辑实时传输,GH中编辑需要先断开组件连接,会破坏连接传输关系。对于用多个ghpython电池的情况,需要在vscode建一个工程文件夹,同时管理编辑多个py文件,每个py文件都对应一个path-readfile-ghpython的组合。
以下是上面示例中的Grasshopper文件,代码见文末:
将需求代码编写为模块,放在ironpython查询路径上C:\\Users\\Dell\\AppData\\Roaming\\McNeel\\Rhinoceros\\6.0\\scripts,导入模块,配置要交互的输入端即可。对于代码修改的实时查看,模块一般只在第一次调入时运行,实时编写调试可通过reload解决。
1import testmodule_name
2
3# 重载模块
4reload(testmodule_name)
5
6# 调用模块函数
7a = testmodule_name.fun(args)
GhPython是一个针对GH的IronPython接口,IronPython是基于.NET框架的python编程语言的开源实现,匹配的python版本是python2.7,电脑安装python3或python2都可以,因为运行的还是在Ironpython中,但编写的时候得遵循python2的编码规则。
python2.x版本的py文件一般默认的是ASCII码,如果文件里有中文,运行时会出现乱码,注释是中文也不行。因此,需要把文件编码类型改为utf-8的类型,输入# -*- coding:utf-8 -*-之后会把文件编码强制转换为utf-8, RhinoPython有这个问题,GhPython貌似默认是utf-8支持,GhPython中可不写。
GH中的ghpython电池在之前的rhino版本中没有,需要从food4rhino单独下载安装,后来GH将其收编进来成为自身组件,如同Rhino把GH收编一样。美中不足的是在外部编辑器中无法调用ghpythonlib(Grasshopper中的电池模块),只能在Grasshopper的界面环境中才可以使用,由于底层架构的不同,外部调用的实现有些难度,在国外论坛看到相关讨论,希望尽快实现。
关于GhPython使用的其他技巧见后续分享。
示例代码:
1# -*- coding:UTF-8 -*-
2
3import rhinoscriptsyntax as rs
4import random
5
6
7def mySpheres(min, max, width=60, nums=20):
8 '''
9 定义一个生成随机球体的函数
10 min\max:最大最小半径
11 width: 球体范围
12 nums: 球体数量
13 '''
14 random.seed(seed)
15 xCoord = [random.randint(0, width) for _ in range(nums)]
16 yCoord = [random.randint(0, width) for _ in range(nums)]
17 zCoord = [random.randint(0, width) for _ in range(nums)]
18 radius = [random.uniform(min, max) for _ in range(nums)]
19
20 spheres = []
21
22 for i in range(nums):
23 pt = rs.AddPoint(xCoord[i], yCoord[i], zCoord[i])
24 sphere = rs.AddSphere(pt, radius[i])
25 spheres.append(sphere)
26
27 return spheres
28
29spheres = mySpheres(min, max)
感谢关注,与你一起进步。
微信公众号
个人微信微信公众号:XrayStudio
关注可了解更多的分享内容, 问题或建议,请公众号留言