PCB genesis自制孔点 Font字体实现方法
一.先看genesis原有Font字体
在PCB工程CAM加孔点字体要求时,通常我们直接用Geneis软件给我们提供了2种孔点字体canned_57与canned_67,但此字体可能不能满足各个工厂个性化需求,比如:孔密度,孔间距,孔形状分布,如果有一些个性化需求时必须得自己可以编辑孔点字体才可以满足要求,可以奥宝没有提供这样的工具给我们,在这里就介绍用genesis自制Font字体实现方法
二.Font字体坐标文件制作说明
Font字符坐标文件放在genesis安装目录:C:\genesis\fw\lib\fonts\下,有2个文件canned_57与canned_67,和孔符坐标一样也是明文坐标,这里我们又可以借助genesis图形界面,将Font字体坐标读入genesis,然对字体坐标进行编辑,接着再将编辑好的Font字体坐标输出来即可.
Font字符制作3步曲.
1.字体坐标读入==>2.编辑字体坐标==>3.字体坐标输出
三.Font字体编辑孔符规则说明
1.由于借助Genesis图形界面编辑Font字体,所以每一层分别带表对应的Char字符,而在Genesis层名不能使用特殊符号作为层名,这里采用ID号作对应关系作为层名,对应关系如下表.当我们编辑字体坐标时,可以通过Char字符找到对应的ID号层名。
2.Genesis第1层的层名是rect ,带表字符Char框架范围,当编辑字体时,孔的中心坐标不能超出rect范围,如超出了可能会造成字体碰撞在一起,这里编辑字体时需注意了。
3. 编辑字体比例规则:【字体宽度】字体宽度与框架宽度 有一个黄金比例关系,字体最大坐标宽度X比框架范围X比值为0.72,所以我们在编辑字体时要尽量尊守,并往这个比例靠笼,【字体高度】无特别要求,尽量保持字体高度与框架高度接近就好了
4. rect框架零点以左下角为零点位置,编辑字体时这个位置不能需随意整体移动的
四.Font字体坐标转换关系说明
这里讲一讲,Font字体坐标文件,Genesis UI界面参数,绘制字体坐标图形 三者坐标转换的计算公式
转换实例:
具体坐标转换关系转换计算器 http://pcbren.cn/CannedText/
五.C#代码实现
另一篇文章有介绍不用Genesis孔点坐标加点阵字的方法,有兴趣可以看一下 PCB Genesis增加点阵字 实现原理
canned_57 fonts 字体读入genesis
//###canned_57 fonts 字体读入genesis
//1.新建一个全新的job与step
//2.读取canned_57 fonts 目录文件
// 每一种字体对应genesis一个层
// rect层:定义字体范围,字宽与字高范围定义
// 层名ID序号:例如:用1,2,3作为层名,对应字符Char ID号(由于genesis层名不能以符号显示)
//3.接着借助genesis对字体进行编辑操作了
string HoleFontsInputDirPath = @"C:\genesis\fw\lib\fonts\canned_57";//孔符读取markers目录
gL RectSizeL = new gL();//rect层 做为字体坐标范围
gP OffsetP = new gP(); //rect层 先取X值作为偏移(目前发现没作用)
List<List<gL>> lineAllList = new List<List<gL>>();
List<gL> lineList = new List<gL>();
var txtList = File.ReadAllLines(HoleFontsInputDirPath);
for (int i = ; i < txtList.Count(); i++)
{
string LayerName = txtList[i];
var arrList = txtList[i].Trim().Replace(" ", " ").Split(' ');
string StartsWith = arrList[];
switch (StartsWith)
{
case "CHAR":
lineList = new List<gL>();
break;
case "LINE":
gPoint ps = new gPoint(double.Parse(arrList[]), double.Parse(arrList[]));
gPoint pe = new gPoint(double.Parse(arrList[]), double.Parse(arrList[]));
double width = double.Parse(arrList[]) * ;
gL tempL = new gL(ps, pe, width);
tempL.negative = arrList[] == "N";
lineList.Add(tempL);
break;
case "ECHAR":
lineAllList.Add(lineList);
break;
case "XSIZE":
RectSizeL.pe.x = double.Parse(arrList[]);
break;
case "YSIZE":
RectSizeL.pe.y = double.Parse(arrList[]);
RectSizeL.width = ;
break;
case "OFFSET":
OffsetP.p.x = double.Parse(arrList[]);
OffsetP.width = ;
break;
}
}
g.COM($"create_layer,layer=rect");
g.COM($"affected_layer,name=rect,mode=single,affected=yes");
addCOM.line_rect(RectSizeL);
addCOM.pad(OffsetP);
g.COM($"affected_layer,name=rect,mode=single,affected=no");
for (int i = ; i < lineAllList.Count(); i++)
{
g.COM($"create_layer,layer={i }");
g.COM($"affected_layer,name={i },mode=single,affected=yes");
for (int j = ; j < lineAllList[i].Count(); j++)
{
addCOM.line(lineAllList[i]);
}
g.COM($"affected_layer,name={i},mode=single,affected=no");
}
var pcbren = "pcbren";
canned_57 fonts 字体输出
////###canned_ fonts字体输出
////1.准备编辑好的字体job
////2.依次遍历genesis所有层,每一层(ID对应一个Char字符) 并将所有层字体坐标合并为一个文件输出
////输出需注意两点
////一.输出孔符的genesis单位要读入孔符单位要一致(TGZ默认数据全部用inch存储,保持读取与输出统一inch)
////二.输出层顺序与层ID号不能修改,不然会导致异常
////此读取此为canned_57字符排序,输出也按此顺序输出
string CharList = @"!""#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~";
var HoleFontsOutputDirPath = @"C:\Users\Administrator\Desktop\markers\";//孔符输出markers目录
LayerNameList = g.getLayerNameList(g.STEP, g.JOB);
StringBuilder StrLineAll = new StringBuilder();
var layer = g.getFEATURES("rect", g.STEP, g.JOB, "inch", true);
var xList = layer.Llist.Select(tt => tt.ps.x).Union(layer.Llist.Select(tt => tt.pe.x));
var yList = layer.Llist.Select(tt => tt.ps.y).Union(layer.Llist.Select(tt => tt.pe.y));
StrLineAll.AppendLine($"XSIZE { (xList.Max() - xList.Min()).ToString("0.000000")}");
StrLineAll.AppendLine($"YSIZE { (yList.Max() - yList.Min()).ToString("0.000000")}");
StrLineAll.AppendLine($"OFFSET { (layer.Plist[0].p.x).ToString("0.000000") }");
StrLineAll.AppendLine("");
StrLineAll.AppendLine("");
for (int i = ; i < CharList.Count(); i++)
{
StrLineAll.AppendLine($"CHAR {CharList[i]}");
foreach (var line in g.getFEATURES(i.ToString(), g.STEP, g.JOB, "inch", true).Llist)
{
string polarity = line.negative ? "N" : "P";
string symbolsStart = line.symbols.StartsWith("r") ? "R" : "S";
StrLineAll.AppendLine($"LINE {line.ps.x.ToString("0.000000")} {line.ps.y.ToString("0.000000")} {line.pe.x.ToString("0.000000")} {line.pe.y.ToString("0.000000")} {polarity} {symbolsStart} {(line.width * 0.001).ToString("0.000000")}");
}
StrLineAll.AppendLine("ECHAR");
StrLineAll.AppendLine("");
}
File.WriteAllText($"{HoleFontsOutputDirPath}{"canned_pcbren"}", StrLineAll.ToString());
var pcbren1 = "pcbren";
六.实现效果
Font坐标读入
Font坐标输出
PCB genesis自制孔点 Font字体实现方法的更多相关文章
- PCB genesis短槽加引导孔实现方法
一.何为短槽 短槽通常定义:槽长小于2倍槽宽 如:槽长1.8mm,槽宽1.0mm 二.为什么要加短槽加引孔呢 短槽孔在钻孔时孔易偏斜导致槽长偏短, 当槽长宽比越小,则受力越不均匀,在钻第2个 ...
- PCB genesis连孔加除毛刺孔(槽孔与槽孔)实现方法(三)
一.为什么 连孔加除毛刺孔 原因是 PCB板材中含有玻璃纤维, 毛刺产生位置在于2个孔相交位置,由于此处钻刀受力不均导致纤维切削不断形成毛刺 ,为了解决这个问题:在钻完2个连孔后,在相交处再钻一个孔, ...
- PCB genesis连孔加除毛刺孔(圆孔与槽孔)实现方法(二)
一.为什么 连孔加除毛刺孔 原因是 PCB板材中含有玻璃纤维, 毛刺产生位置在于2个孔相交位置,由于此处钻刀受力不均导致纤维切削不断形成毛刺 ,为了解决这个问题:在钻完2个连孔后,在相交处再钻一个孔, ...
- PCB genesis连孔加除毛刺孔(圆孔与圆孔)实现方法(一)
一.为什么 连孔加除毛刺孔 原因是 PCB板材中含有玻璃纤维, 毛刺产生位置在于2个孔相交位置,由于此处钻刀受力不均导致纤维切削不断形成毛刺 ,为了解决这个问题:在钻完2个连孔后,在相交处再钻一个孔, ...
- PCB genesis 大孔扩孔(不用G84命令)实现方法
PCB钻孔时,当钻刀>6.3mm时,超出钻孔范围,钻孔工序是没有这么大的钻刀,当这种情况,工程CAM会都采用G84命令用小孔扩孔的方式制作, 在这里介绍一种如果不用G84命令,用程序实现将大孔生 ...
- PCB genesis大孔加小孔(即卸力孔)实现方法
一.为什么 大孔中要加小孔(即卸力孔) 这其实跟钻刀的排屑有关了,当钻刀越大孔,排屑量也越大(当然这也得跟转速,下刀速的参数有关系),通常当钻刀越大,转速越慢,下刀速也越慢(因为要保证它的排屑通畅). ...
- PCB Genesis拼SET画工艺边 实现方法(一)
在PCB行业中,客户提供的PCB尺寸较小,为方便PCB加工,并生产提高生产效率,通常小于80X80mm需拼板处理的, 拼板要求可能来自按户指定拼板,也有可能是由工厂自行拼板,但对于CAM来说就需将PC ...
- PCB Genesis或Incam 右键导入TGZ 实现方法
使用Genesis导入TGZ方式很多 的,比如有:写个脚本框选TGZ的的方式实现TGZ导入,将TGZ拖入脚本界面实现TGZ导入, 给Engineering Toolkit窗口句柄注册拖拽事件实现TGZ ...
- PCB Genesis脚本C#使用WPF窗体实现方法
用C#写脚本做UI界面基本上都是用WinForm界面,如果想制作很漂亮动态的界面用WPF界面挺不错的选择, 这里介绍如何使用控制台程序调用WPF窗口 一.方法一 在控制台程序中,通过Main方法启动W ...
随机推荐
- linux 系统 UDP 丢包问题分析思路
转自:http://cizixs.com/2018/01/13/linux-udp-packet-drop-debug?hmsr=toutiao.io&utm_medium=toutiao.i ...
- Bullet:ORACLE Using SQL Plan Management(一)
SQL Plan Management如何工作? 当一个SQL硬解析时,基于成本的优化器CBO会生成多个执行计划,并从这些执行计划中选择一个优化器认为最低成本的执行计划. 如果SQL plan bas ...
- rem js 自适应布局
(function(doc, win) { resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',//o ...
- ubuntu中mysql忘记密码如何修改
1.在终端进入安装目录下:cd /etc/mysql 2.sudo cat debian.cnf 输入密码 3用如下图用户和密码登录 4.进入mysql use mysql 5.使用describe ...
- React组件设计技巧
React组件设计 组件分类 展示组件和容器组件 展示组件 容器组件 关注事物的展示 关注事物如何工作 可能包含展示和容器组件,并且一般会有DOM标签和css样式 可能包含展示和容器组件,并且不会有D ...
- 对象和变量的并发访问synchronized解析以及死锁分析排查
一.synchronized java并发编程中存在“非线程安全"问题.“非线程安全"是指发生在多个线程对同一个对象中的实例变量并发访问时,产生的”脏读“现象,使用synchron ...
- HDU——1267 下沙的沙子有几粒?
下沙的沙子有几粒? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...
- [codevs 1243][网络提速(最短路分层思想)
题目:http://dev.codevs.cn/problem/1243/ 分析: 先容易想到将一个点拆成m个点,分别对应不同的边连过去,但是想不到控制加速器数量的办法.看了题解才知道,每个点的分层, ...
- eclipse下载egit插件,实现代码git同步问题
1.使用egit后,怎样查看历史log信息? : Team -> Show in history可以查看版本历史提交记录 2.每次代码提交前,先fetch,再merge. 先fetch获得最新代 ...
- 关于SVN版本冲突问题
版本冲突原因: 假设A.B两个用户都在版本号为100的时候,更新了kingtuns.txt这个文件,A用户在修改完成之后提交kingtuns.txt到服务器,这个时候提交成功,这个时候kingtuns ...