一.先看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字体实现方法的更多相关文章

  1. PCB genesis短槽加引导孔实现方法

    一.何为短槽 短槽通常定义:槽长小于2倍槽宽      如:槽长1.8mm,槽宽1.0mm 二.为什么要加短槽加引孔呢 短槽孔在钻孔时孔易偏斜导致槽长偏短, 当槽长宽比越小,则受力越不均匀,在钻第2个 ...

  2. PCB genesis连孔加除毛刺孔(槽孔与槽孔)实现方法(三)

    一.为什么 连孔加除毛刺孔 原因是 PCB板材中含有玻璃纤维, 毛刺产生位置在于2个孔相交位置,由于此处钻刀受力不均导致纤维切削不断形成毛刺 ,为了解决这个问题:在钻完2个连孔后,在相交处再钻一个孔, ...

  3. PCB genesis连孔加除毛刺孔(圆孔与槽孔)实现方法(二)

    一.为什么 连孔加除毛刺孔 原因是 PCB板材中含有玻璃纤维, 毛刺产生位置在于2个孔相交位置,由于此处钻刀受力不均导致纤维切削不断形成毛刺 ,为了解决这个问题:在钻完2个连孔后,在相交处再钻一个孔, ...

  4. PCB genesis连孔加除毛刺孔(圆孔与圆孔)实现方法(一)

    一.为什么 连孔加除毛刺孔 原因是 PCB板材中含有玻璃纤维, 毛刺产生位置在于2个孔相交位置,由于此处钻刀受力不均导致纤维切削不断形成毛刺 ,为了解决这个问题:在钻完2个连孔后,在相交处再钻一个孔, ...

  5. PCB genesis 大孔扩孔(不用G84命令)实现方法

    PCB钻孔时,当钻刀>6.3mm时,超出钻孔范围,钻孔工序是没有这么大的钻刀,当这种情况,工程CAM会都采用G84命令用小孔扩孔的方式制作, 在这里介绍一种如果不用G84命令,用程序实现将大孔生 ...

  6. PCB genesis大孔加小孔(即卸力孔)实现方法

    一.为什么 大孔中要加小孔(即卸力孔) 这其实跟钻刀的排屑有关了,当钻刀越大孔,排屑量也越大(当然这也得跟转速,下刀速的参数有关系),通常当钻刀越大,转速越慢,下刀速也越慢(因为要保证它的排屑通畅). ...

  7. PCB Genesis拼SET画工艺边 实现方法(一)

    在PCB行业中,客户提供的PCB尺寸较小,为方便PCB加工,并生产提高生产效率,通常小于80X80mm需拼板处理的, 拼板要求可能来自按户指定拼板,也有可能是由工厂自行拼板,但对于CAM来说就需将PC ...

  8. PCB Genesis或Incam 右键导入TGZ 实现方法

    使用Genesis导入TGZ方式很多 的,比如有:写个脚本框选TGZ的的方式实现TGZ导入,将TGZ拖入脚本界面实现TGZ导入, 给Engineering Toolkit窗口句柄注册拖拽事件实现TGZ ...

  9. PCB Genesis脚本C#使用WPF窗体实现方法

    用C#写脚本做UI界面基本上都是用WinForm界面,如果想制作很漂亮动态的界面用WPF界面挺不错的选择, 这里介绍如何使用控制台程序调用WPF窗口 一.方法一 在控制台程序中,通过Main方法启动W ...

随机推荐

  1. <MyBatis>入门八 工作原理

    1.获取sqlSessionFactory对象 首先拿到全局配置文件的流对象 创建SqlSessionFactoryBuilder对象,并调用build方法,把流传进去 build方法 创建一个XML ...

  2. Hadoop Mapreduce 中的Partitioner

    Partitioner的作用的对Mapper产生的中间结果进行分片,以便将同一分组的数据交给同一个Reduce处理,Partitioner直接影响Reduce阶段的负载均衡. MapReduce提供了 ...

  3. zabbix登录密码重置方法

    注:由于账号较多,难免忘记账号,下面是找回zabbix登录密码的过程. 一.登录zabbix数据库 [root@123 ~]# mysql -uroot -p密码 二.修改zabbix密码 mysql ...

  4. SQL Server数据库基础编程

    转载,查看原文 Ø Go批处理语句 用于同时执行多个语句 Ø 使用.切换数据库 use master go   Ø 创建.删除数据库 方法1. --判断是否存在该数据库,存在就删除 if (exist ...

  5. 洛谷 1541 NOIp2010提高组 乌龟棋

    [题解] 很容易想到这是一个DP,f[i][j][k][l]表示4种卡片分别用了多少张,那么转移方程就是f[i][j][k][l]=Max(f[i-1][j][k][l],f[i][j-1][k][l ...

  6. c# 缓存!

    做项目的时候获取所有城市的时候,发现每次去获取都花费了很多时间,所以用缓存方法让效率更高! 这是我做的例子,如下: public class CacheGetCity { /// <summar ...

  7. HDU 1203 背包问题

    题目大意: 根据学校的申请费用,根据已有的钱得到最大的offer率 这里很明显就是一个价值为概率的背包问题 计算两个offer合并的概率 为a + b - a*b #include <cstdi ...

  8. hash扩展长度攻击及hashdump使用

    摘自: 1.http://www.freebuf.com/articles/web/69264.html 2.https://www.cnblogs.com/pcat/p/5478509.html 0 ...

  9. NOIP2014 提高组合集

    NOIP 2014 提高组 合集 D1 T1 生活大爆炸版石头剪刀布 首先,先将两个人的猜拳序列都变得不小于n.然后逐个模拟.胜败什么的看表就行了. #include <iostream> ...

  10. c++面试问题的几个方向

    1 关于多态,面向对象的几个要点作为面向对象的程序员,这个问题是必须要弄清楚的,网上.教科书上都是标准答案,关键是理解内涵哦. 2 关于虚函数表和RTTI 这个Inside C++ Object Mo ...