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 = 0; i < txtList.Count(); i++) { string LayerName = txtList[i]; var arrList = txtList[i].Trim().Replace(" ", " ").Split(' '); string StartsWith = arrList[0]; switch (StartsWith) { case "CHAR": lineList = new List<gL>(); break; case "LINE": gPoint ps = new gPoint(double.Parse(arrList[1]), double.Parse(arrList[2])); gPoint pe = new gPoint(double.Parse(arrList[3]), double.Parse(arrList[4])); double width = double.Parse(arrList[7]) * 1000; gL tempL = new gL(ps, pe, width); tempL.negative = arrList[7] == "N"; lineList.Add(tempL); break; case "ECHAR": lineAllList.Add(lineList); break; case "XSIZE": RectSizeL.pe.x = double.Parse(arrList[1]); break; case "YSIZE": RectSizeL.pe.y = double.Parse(arrList[1]); RectSizeL.width = 1; break; case "OFFSET": OffsetP.p.x = double.Parse(arrList[1]); OffsetP.width = 2; 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 = 0; i < lineAllList.Count(); i++) { g.COM($"create_layer,layer={i }"); g.COM($"affected_layer,name={i },mode=single,affected=yes"); for (int j = 0; 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 = 0; 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坐标输出
作者:pcbren 微信号:yadnfku QQ号: 254566449
博客地址:https://www.cnblogs.com/pcbren/
声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权,贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。
如果大家感觉我的博文对大家有帮助,请推荐支持一把。