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 kernel-汇编基础
mov ASSEMABLE C LANGUAGE movl %eax,%edx edx = eax; --->register mode movl $0x123,%edx edx = 0x123 ...
- 比较synchronized和读写锁
一.科普定义 这篇博文的两个主角“synchronized”和“读写锁” 1)synchronized 这个同步关键字相信大家都用得比较多,在上一篇“多个线程之间共享数据的方式”中也详细列举他的应用, ...
- [Python数据结构] 使用 Circular List实现Queue
[Python数据结构] 使用 Circular List实现Queue 1. Queue队列,又称为伫列(queue),是先进先出(FIFO, First-In-First-Out)的线性表.在具体 ...
- oracle 清理跟踪文件.trc .trm
trc,trm文件介绍:trc:系统的跟踪文件(trace),当系统启动时或运行过程中出现错误时,系统会自动记录跟踪文件到指定的目录,以便于检查,这些文件需定期维护删除.trm:伴随着.trc文件产生 ...
- buf.readUInt8()
buf.readUInt8(offset[, noAssert]) offset {Number} 0 <= offset <= buf.length - 1 noAssert {Bool ...
- Django中的模板变量
示例文件: template_variable_demo.zip
- vue中axios设置
//设置默认全局baseURL axios.defaults.baseURL=process.env.BASE_API; //设置默认全局携带浏览器cookie axios.defaults.with ...
- PAT 1126 Eulerian Path
In graph theory, an Eulerian path is a path in a graph which visits every edge exactly once. Similar ...
- Neo4j 的一些使用心得
由对图数据的处理需求,看到了图数据库(GraphDataBase)这种比较新的数据库模式,并且通过比较发现用的相对多的要属Neo4j了,现在来看网上对Neo4j的介绍还比较少,内容主要来源于三个地方: ...
- Linux command2
. CentOS 想查看哪个port开了,却提示命令无效 # yum -y install net-tools 2. How to install "wget" command i ...