@@ -85,13 +85,13 @@ void delete(string atPoint)
// schliesst die outline
// schliesst die outline
void closeBoundary(real radius, real hoehe, real mittelabstand_links, real mittelabstand_rechts)
void closeBoundary(real slotwidth, real radius, real hoehe, real mittelabstand_links, real mittelabstand_rechts)
{
{
str += "LAYER 20;\nDISPLAY NONE;\nDISPLAY 20;\n";
str += "LAYER 20;\nDISPLAY NONE;\nDISPLAY 20;\n";
// setzt das grid auf mm fuer folgende operationen
// setzt das grid auf mm fuer folgende operationen
str += "GRID mm 0.1;\n";
str += "GRID mm 0.1;\n";
group(0, hoehe - 0.1, 100, 2 );
group(0, hoehe - 0.1, 100, 4 );
delete("(C> 0 0)");
delete("(C> 0 0)");
delete(Point(10, hoehe));
delete(Point(10, hoehe));
delete(Point(50-10, hoehe));
delete(Point(50-10, hoehe));
@@ -99,13 +99,15 @@ void closeBoundary(real radius, real hoehe, real mittelabstand_links, real mitte
delete(Point(50+10, hoehe));
delete(Point(50+10, hoehe));
delete(Point(100-10, hoehe));
delete(Point(100-10, hoehe));
delete(Point(0,0));
delete(Point(50,0));
// reproduziere die seitenkanten
line(0, Point( 0, hoehe - radius), "( 0 0)");
line(0, Point(radius, hoehe), Point(25 - mittelabstand_links, hoehe));
line(0, Point(radius, hoehe), Point(25 - mittelabstand_links, hoehe));
line(0, Point(25 + mittelabstand_rechts, hoehe), Point(50 - radius, hoehe));
line(0, Point(25 + mittelabstand_rechts, hoehe), Point(50 - radius, hoehe));
line(0, Point(0,0), Point(25-slotwidth/2, 0));
line(0, Point(50, 0), Point(25+slotwidth/2, 0));
// reproduziere die abgerundeten ecken
// reproduziere die abgerundeten ecken
arc(0, Point(0, hoehe - radius), Point(radius, hoehe) , -90);
arc(0, Point(0, hoehe - radius), Point(radius, hoehe) , -90);
@@ -121,20 +123,29 @@ void hole(real drill, string point)
str += temp;
str += temp;
}
}
void placeJlcMark()
{
str += "LAYER 22;\nCHANGE FONT VECTOR;\nGRID mm;\nCHANGE SIZE 0.8;\nCHANGE ALIGN bottom-right;\nTEXT 'JLCJLCJLCJLC' MR0 (51 1);\n";
}
// prozessiert eine seite des PCBs
// prozessiert eine seite des PCBs
void side(string name, real originX, real originY, real radius, real hoehe, real abstand_l, real abstand_r) {
void side(string name, real originX, real originY, real slot, real radius, real hoehe, real abstand_l, real abstand_r) {
cut(originX, originY);
cut(originX, originY);
edit(name);
edit(name);
clearBrd();
clearBrd();
paste(0, 0, 0);
paste(0, 0, 0);
closeBoundary(radius, hoehe, abstand_l, abstand_r);
closeBoundary(slot, radius, hoehe, abstand_l, abstand_r);
// sie panele sollen seitensymmetrisch sein
// sie panele sollen seitensymmetrisch sein
// damit die zerbrochen platine die trennungsartifakte
// damit die zerbrochen platine die trennungsartifakte
// immer auf der rechten bzw. linken seite aufweist
// immer auf der rechten bzw. linken seite aufweist
str += "GRID mm;\nGROUP ALL;\nCUT (0 0);\nPASTE MR0 (10 0 0);\n";
str += "GRID mm;\nGROUP ALL;\nCUT (0 0);\nPASTE R0 (5 0 0);\n";
// reproduziere die seitenkanten
line(0, Point( 0, hoehe - radius), "( 0 0)");
line(0, Point(100, hoehe - radius), "(100 0)");
// trennungshilfen setzten
// trennungshilfen setzten
real holedrill = 0.5;
real holedrill = 0.5;
real slotwidth = 0.5;
real slotwidth = 0.5;
@@ -148,14 +159,13 @@ void side(string name, real originX, real originY, real radius, real hoehe, real
line(slotwidth, Point(50, hoehe-radius-1-numholes), Point(50, numholes));
line(slotwidth, Point(50, hoehe-radius-1-numholes), Point(50, numholes));
// alle dimensionsmarken loeschen
// alle dimensionsmarken loeschen
str += "DISPLAY none;\ndisplay 47;\ngroup all;\ndelete (C> 0 0);\ndisplay all;\n";
str += "DISPLAY none;\ndisplay 47 48;\nGROUP all;\nDELETE (C> 0 0);\nDISPLAY all;\n";
str += "GRID last;\n";
str += "GRID last;\n";
// fuelle polygone
// fuelle polygone
str += "rats;\n";
// str += "rats;\n";
// jlc markierung plazieren
// jlc markierung plazieren
str += "LAYER 21;\nCHANGE FONT VECTOR;\nGRID mm;\nCHANGE SIZE 0.8;\nTEXT 'JLCJLCJLCJLC' R180 (98 2);\n";
write();
placeJlcMark();
}
}
// verhindert, dass das skript auf was anderes als boards angewendet wird
// verhindert, dass das skript auf was anderes als boards angewendet wird
@@ -168,21 +178,39 @@ board(B){
// um es spaeter wieder zu oeffnen
// um es spaeter wieder zu oeffnen
string master = B.name;
string master = B.name;
// save drc settings
string drcfile = "";
sprintf(drcfile, "%s/master_drc_settings", filedir(master));
str += "SET CONFIRM YES; DRC SAVE '" + drcfile + "'; SET CONFIRM OFF;";
// maskieren von Seite 1
// maskieren von Seite 1
str += "DISPLAY all;\n";
str += "DISPLAY all;\n";
group(0, 110, 49.5, -10);
group(0, 110, 49.5, -10);
side("SideA.brd", 0,0, radius, hoehe, 6.9, 5.7);
side("SideA.brd", 0,0, 1.7, radius, hoehe, 6.9, 5.7);
// drc einstellungen laden
str += "DRC LOAD '" + drcfile + "';";
// datei speichern
write();
// zurueck zum master fuer seite 2
// zurueck zum master fuer seite 2
edit(master);
edit(master);
str += "DISPLAY all;\n";
str += "DISPLAY all;\n";
// maskieren von Seite 2
// maskieren von Seite 2
group(50.5, 110, 100, -10);
group(50.5, 110, 100, -10);
side("SideB.brd", 50,0, radius, hoehe, 7.3, 5.9);
side("SideB.brd", 50,0, 0, radius, hoehe, 7.3, 5.9);
// DRC einstellungen laden
str += "DRC LOAD '" + drcfile + "';";
// datei speichern
write();
// master wieder oeffnen
// master wieder oeffnen
edit(master);
edit(master);
// generierten code als skript zu eagle zurueckgeben
// generierten code als skript zu eagle zurueckgeben
exit(str);
exit(str);
}
}