123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984 |
- #! /bin/sh
- # restart using wish \
- exec /sppdg/software/tools/public_domain/${HOST_TYPE}/bin/wish "$0" "$@"
- global curPosition
- global openFile
- # the number of each kind of conductor and dielectric
- global fileHead;
- global dieleData recData cirData triData ellData polyData gndData
- ### global variables for saving all parameters of each kind
- global palFlag
- global corFlag
- global newFlag
- global yesMove
- global recCounter cirCounter dieleCounter ellCounter triCounter polyCounter \
- gndCounter
- global recTags cirTags dieleTags ellTags triTags polyTags gndTags
- global recId cirId dieleId ellId triId polyId gndId
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- global pData
- global pcal
- global od maxga
- set fileHead { 0 0 0 0 0 0 0 }; # dieleNum recNum cirNum triNum ellNum polyNum gndNum
- set palFlag -1
- set corFlag -1; # initially set to new mode
- set newFlag -1
- set yesMove -1
- set curPosition -1
- set recCounter 0
- set cirCounter 0
- set dieleCounter 0
- set ellCounter 0
- set triCounter 0
- set polyCounter 0
- set gndCounter 0
- set recId ""
- set cirId ""
- set dieleId ""
- set ellId ""
- set triId ""
- set polyId ""
- set gndId ""
- set recData ""
- set cirData ""
- set dieleData ""
- set ellData ""
- set triData ""
- set polyData ""
- set gndData ""
- set recTags ""
- set cirTags ""
- set dieleTags ""
- set ellTags ""
- set triTags ""
- set polyTags ""
- set gndTags ""
-
- set pData ""
- set pcal ""
- set maxXcoord 879.00000
- set maxYcoord 586.00000
- set paletteXsize 0
- set paletteYsize 0
- set pbottomleftX 0
- set pbottomleftY 0
- set Xscale 0
- set Yscale 0
- set Nh 1024
- set Nit 40
- set J 6
-
- set Nwx 8
- set Nwy 10
- set Nws 5
- set Np 0.0
- set Eps 1.0e-5
- set matr 2
- set od 5
- set maxga 0
- #########################################################################
- #
- #
- # Capacitance Calculation using Coifman wavelets
- # for the method of moments
- #
- # By Zhichao Zhang
- # 2001.5
- #
- #
- #########################################################################
- #########################################################################
- # NAME: global_init
- # PURPOSE: define the global variables which decide the state of
- # display mode
- #
- #########################################################################
- proc global_init { } {
- global palettebkcolor
- createMenu
- }
- #########################################################################
- # NAME: createMenu
- # PURPOSE: create the main menu
- #
- #########################################################################
- proc createMenu { } {
- frame .mbar -relief raised -bd 2
- frame .dummy1 -relief raised -width 20c -height 0.05c -background blue
- frame .dummy -width 24c -height 0.5c -background black
- #########################################################################
- canvas .c -width 24c -height 16c -background black \
- -xscrollcommand ".shoriz set" \
- -yscrollcommand ".svert set"
- scrollbar .svert -orient v -command ".c yview"
- scrollbar .shoriz -orient h -command ".c xview"
- frame .butt
- button .butt.rect -text "Rectangle" -command mkRect -background lightblue -foreground black
- button .butt.cir -text "Circle" -command mkCir -background lightblue -foreground black
- button .butt.poly -text "Trapezoid" -command mkPoly -background lightblue -foreground black
- button .butt.gnd -text "Ground Plate" -command mkGnd -background lightblue -foreground black
- button .butt.diele -text "Dieletric" -command mkDiele -background lightblue -foreground black
- button .butt.move -text "Move" -command moveUnit -background lightyellow -foreground black
- button .butt.delete -text "Delete" -command delUnit -background lightyellow -foreground black
- label .dummy.status -text " Status Bar " -background orange
- label .dummy.statusCon -text "You are welcome to use this Program!" -background black
- button .dummy.eplicon -bitmap @/sppdg/software/bin/hpux10/epl.bit -background black -foreground white -command eplIntro
- ##############################################################################
-
- pack .mbar .c .butt .dummy1 .dummy -side top -fill x
- pack .butt.rect .butt.cir .butt.poly .butt.gnd .butt.diele -side left
- pack .butt.move .butt.delete -side right
- pack .dummy.eplicon .dummy.status .dummy.statusCon -side left
-
- menubutton .mbar.file -text File \
- -menu .mbar.file.menu
- menubutton .mbar.edit -text Edit \
- -menu .mbar.edit.menu
- menubutton .mbar.setup -text Setup \
- -menu .mbar.setup.menu
- menubutton .mbar.handcreate -text HandCreate \
- -menu .mbar.handcreate.menu
- menubutton .mbar.dropcreate -text DropCreate \
- -menu .mbar.dropcreate.menu
- menubutton .mbar.calculate -text Calculate \
- -menu .mbar.calculate.menu
- menubutton .mbar.help -text About \
- -menu .mbar.help.menu
- pack .mbar.file .mbar.edit .mbar.setup \
- .mbar.handcreate .mbar.dropcreate .mbar.calculate -side left
- pack .mbar.help -side right
- menu .mbar.file.menu
- .mbar.file.menu add command -label "New" \
- -command myAppFileNew
- .mbar.file.menu add command -label "Open" \
- -command myAppFileOpen
- .mbar.file.menu add command -label "Save" \
- -command {myAppFileSave $myAppFileName}
- .mbar.file.menu add command -label "Save As" \
- -command myAppFileSaveAs
- .mbar.file.menu add command -label "Close" \
- -command myAppFileClose
- .mbar.file.menu add separator
- .mbar.file.menu add cascade -label "Print" \
- -menu .mbar.file.menu.print
- .mbar.file.menu add separator
- .mbar.file.menu add command -label "Exit" \
- -command myAppExit
- menu .mbar.file.menu.print
- .mbar.file.menu.print add command -label "Geometrical Parameters" -command printPara
- .mbar.file.menu.print add command -label "Calculation Parameters" -command printcal
- .mbar.file.menu.print add command -label "Print Canvas" -command printGraph
- menu .mbar.edit.menu
- .mbar.edit.menu add command -label "Move" \
- -command moveUnit
- .mbar.edit.menu add command -label "Delete" \
- -command delUnit
- .mbar.edit.menu add separator
- .mbar.edit.menu add command -label "Geometry" \
- -command editPara
- menu .mbar.setup.menu
- .mbar.setup.menu add command -label "Option" \
- -command \
- { Coption .palettePara { Palette Parameters } 0 }
- .mbar.setup.menu add command -label "Parameters" \
- -command \
- { calpara .calPara { Computational Parameters } }
- menu .mbar.handcreate.menu
- .mbar.handcreate.menu add command -label "Dielectric" \
- -command {
- set corFlag -1
- ## puts $corFlag
- dispDiele .dielePara { Dielectric Parameters } {}
- }
- .mbar.handcreate.menu add command -label "Rectangle" \
- -command {
- set corFlag -1
- ## puts $corFlag
- dispRect .rectPara { Rectangular Conductor Parameters } {}
- }
- .mbar.handcreate.menu add command -label "Circle" \
- -command {
- set corFlag -1
- ## puts $corFlag
- dispCir .cirPara { Circular Conductor Parameters } {}
- }
- .mbar.handcreate.menu add command -label "Trapezoid" \
- -command {
- set corFlag -1
- ## puts $corFlag
- getApexnum
- }
- .mbar.handcreate.menu add command -label "Ground" \
- -command {
- set corFlag -1
- ## puts $corFlag
- dispGnd .gndPara { Ground Plane Parameters } {}
- }
- menu .mbar.dropcreate.menu
- .mbar.dropcreate.menu add command -label "Dieletric" \
- -command mkDiele
- .mbar.dropcreate.menu add command -label "Rectangle" \
- -command mkRect
- .mbar.dropcreate.menu add command -label "Circle" \
- -command mkCir
- .mbar.dropcreate.menu add command -label "Trapezoid" \
- -command mkPoly
- .mbar.dropcreate.menu add command -label "Ground" \
- -command mkGnd
- menu .mbar.calculate.menu
- .mbar.calculate.menu add command -label "Check Data" \
- -command { startcal1 1 }
- .mbar.calculate.menu add command -label "Start Calculation" \
- -command { startcal1 2 }
- .mbar.calculate.menu add command -label "Check Results" \
- -command { checkResult }
- menu .mbar.help.menu
- .mbar.help.menu add command -label "About..." \
- -command about
- .mbar.help.menu add command -label "Readme..." \
- -command viewreadme
- tk_menuBar .mbar .mbar.file .mbar.edit .mbar.view .mbar.setup \
- .mbar.handcreate .mbar.dropcreate .mbar.calculate .mbar.help
- focus .mbar
- }
- #########################################################################
- # NAME: editPara
- # PURPOSE: edit the parameters of single objects in the palette
- #
- #########################################################################
- proc editPara { } {
- global dieleData recData cirData triData ellData polyData gndData
- global recTags cirTags dieleTags ellTags triTags polyTags gndTags
- global recId cirId dieleId ellId triId polyId gndId
- global palFlag
- global newFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
-
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- bind .c <Motion> {
- set realX [expr { %x/$Xscale+$pbottomleftX }]
- set realY [expr { ($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
- }
-
- bind .c <Button-1> {
- set curPoint [.c find withtag current]
- ## puts $curPoint
-
- if { [lsearch -exact $recId $curPoint] != -1 } {
- setTag $curPoint $recId $recTags $recData
- set corFlag 0
- ## puts $corFlag
- ## puts "current position: $curPosition"
- set title "Correct Rectangle No. "
- set title1 [lindex $recData [expr { $curPosition+1 }]]
- set title $title$title1
- dispRect .rectPara $title $curPosition
- } elseif { [lsearch -exact $cirId $curPoint] != -1 } {
- setTag $curPoint $cirId $cirTags $cirData
- set corFlag 0;# set the correcting mode
- ## puts $corFlag
- set title "Correct Circle No. "
- set title1 [lindex $cirData [expr { $curPosition+1 }]]
- set title $title$title1
- dispCir .cirPara $title $curPosition
- } elseif { [lsearch -exact $dieleId $curPoint] != -1 } {
- setTag $curPoint $dieleId $dieleTags $dieleData
- set corFlag 0;# set the correcting mode
- ## puts $corFlag
- set title "Correct Dielectric No. "
- set title1 [lindex $dieleData [expr { $curPosition+1 }]]
- set title $title$title1
- dispDiele .dielePara $title $curPosition
- } elseif { [lsearch -exact $triId $curPoint] != -1 } {
- setTag $curPoint $triId $triTags $triData
- set corFlag 0;# set the correcting mode
- ## puts $corFlag
- set title "Correct Triangle No. "
- set title1 [lindex $triData [expr { $curPosition+1 }]]
- set title $title$title1
- dispTri .triPara $title $curPosition
- } elseif { [lsearch -exact $ellId $curPoint] != -1 } {
- setTag $curPoint $ellId $ellTags $ellData
- set corFlag 0;# set the correcting mode
- ## puts $corFlag
- set title "Correct Ellipse No. "
- set title1 [lindex $ellData [expr { $curPosition+1 }]]
- set title $title$title1
- dispEll .ellPara $title $curPosition
- } elseif { [lsearch -exact $polyId $curPoint] != -1 } {
- setTag $curPoint $polyId $polyTags $polyData
- set corFlag 0;# set the correcting mode
- ## puts $corFlag
- set title "Correct Trapezoid No. "
- set title1 [lindex $polyData [expr { $curPosition+1 }]]
- set title $title$title1
- dispPoly .polyPara $title \
- [lindex $polyData [expr { $curPosition+2 }]] $curPosition
- } elseif { [lsearch -exact $gndId $curPoint] != -1 } {
- setTag $curPoint $gndId $gndTags $gndData
- set corFlag 0;# set the correcting mode
- ## puts $corFlag
- set title "Correct Ground No. "
- set title1 [lindex $gndData [expr { $curPosition+1 }]]
- set title $title$title1
- dispGnd .gndPara $title $curPosition
- }
- }
- }
- ################################################################################################
- # Here below is to draw different shapes
- #
- ################################################################################################
- proc mkRect { } {
- global firstnodex firstnodey
- global secondnodex secondnodey
- global tempnodex tempnodey
- global buttonflag
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag
- global newFlag
- global myAppChangedFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
-
- set buttonflag 0
- .c config -cursor { cross red white }
-
- bind .c <Motion> {
- set realX [expr { %x/$Xscale+$pbottomleftX }]
- set realY [expr { ($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- ## puts "begin1"
- ## puts $pbottomleftY
- ## puts $Yscale
- ## puts $maxYcoord
- ## puts $paletteYsize
- ## puts $paletteXsize
-
- ## puts "end1"
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $buttonflag == 1 } {
-
- .c delete interrect
- .c create rectangle $tempnodex $tempnodey %x %y -outline blue \
- -tags interrect
- }
- }
- bind .c <Button-1> {
-
- if { $buttonflag == 1 } {
- .c delete interrect
- incr recCounter
-
- set rect [.c create rectangle $tempnodex $tempnodey %x %y \
- -outline white -fill yellow -tags recTags$recCounter ]
-
- lappend recId $rect
- lappend recTags recTags$recCounter
-
- ## puts $recTags
-
- set firstnodex($rect) $tempnodex
- set firstnodey($rect) $tempnodey
- set secondnodex($rect) %x
- set secondnodey($rect) %y
- ## puts $rect
- ## puts $firstnodex($rect)
- ## puts $firstnodey($rect)
- ## puts $secondnodex($rect)
- ## puts $secondnodey($rect)
- set buttonflag 0
-
- set fileHead [lreplace $fileHead 1 1 [expr { [lindex $fileHead 1]+1 }]]
- ## puts $fileHead
-
- lappend recData "REC"
- lappend recData $rect
- lappend recData recTags$recCounter
- lappend recData $recCounter
-
- if { $firstnodex($rect) <= $secondnodex($rect) } {
- set bottomleftX [expr { $firstnodex($rect)/$Xscale+$pbottomleftX }]
- } else {
- set bottomleftX [expr { $secondnodex($rect)/$Xscale+$pbottomleftX }]
- }
-
- if { $firstnodey($rect) >= $secondnodey($rect) } {
- set bottomleftY [expr { ($maxYcoord-$firstnodey($rect))/$Yscale+$pbottomleftY }]
- } else {
- set bottomleftY [expr { ($maxYcoord-$secondnodey($rect))/$Yscale+$pbottomleftY }]
- }
-
- lappend recData $bottomleftX
- lappend recData $bottomleftY
-
- lappend recData [expr {abs($firstnodex($rect)-$secondnodex($rect))/$Xscale }]
- lappend recData [expr {abs($firstnodey($rect)-$secondnodey($rect))/$Yscale }]
-
- set myAppChangedFlag 1
-
- ## puts $recData
-
- } else {
- set tempnodex %x
- set tempnodey %y
- set buttonflag 1
-
- }
- }
-
- bind .c <Button-3> {
- .c delete interrect
- set buttonflag 0
- }
- return
-
- }
- proc mkCir { } {
- global firstnodex firstnodey
- global secondnodex secondnodey
- global tempnodex tempnodey
- global buttonflag
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag newFlag
- global myAppChangedFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- .c config -cursor { cross red white }
- set buttonflag 0
- bind .c <Motion> {
-
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $buttonflag == 1 } {
-
- .c delete interrect
- set radius [expr {hypot(($tempnodex-%x),($tempnodey-%y)) }]
- ## puts $radius
- .c create oval [expr {$tempnodex-$radius }] [expr {$tempnodey-$radius }]\
- [expr {$tempnodex+$radius }] [expr {$tempnodey+$radius }] -outline blue -tags interrect
- }
- }
-
- bind .c <Button-1> {
-
- if { $buttonflag == 1 } {
- .c delete interrect
- set radius [expr {hypot(($tempnodex-%x),($tempnodey-%y)) }]
- ## puts $radius
- incr cirCounter
- set cir [.c create oval [expr {$tempnodex-$radius }] [expr {$tempnodey-$radius }] \
- [expr {$tempnodex+$radius }] [expr {$tempnodey+$radius }] \
- -outline white -fill red -tags cirTags$cirCounter]
- lappend cirId $cir
- lappend cirTags cirTags$cirCounter
-
- set firstnodex($cir) $tempnodex
- set firstnodey($cir) $tempnodey
- set secondnodex($cir) %x
- set secondnodey($cir) %y
- ## puts $cir
- ## puts $firstnodex($cir)
- ## puts $firstnodey($cir)
- ## puts $secondnodex($cir)
- ## puts $secondnodey($cir)
- set buttonflag 0
-
- set fileHead [lreplace $fileHead 2 2 [expr {[lindex $fileHead 2]+1 }]]
- ## puts $fileHead
-
- lappend cirData "CIR"
- lappend cirData $cir
- lappend cirData cirTags$cirCounter
- lappend cirData $cirCounter
-
- lappend cirData [expr {$firstnodex($cir)/$Xscale+$pbottomleftX }]
- lappend cirData [expr {($maxYcoord-$firstnodey($cir))/$Yscale+$pbottomleftY }]
-
- lappend cirData [expr {hypot(($firstnodex($cir)-$secondnodex($cir))/$Xscale, \
- ($firstnodey($cir)-$secondnodey($cir))/$Yscale) }]
-
- set myAppChangedFlag 1
-
- ## puts $cirData
-
- } else {
- set tempnodex %x
- set tempnodey %y
- set buttonflag 1
- }
- }
-
- bind .c <Button-3> {
-
- .c delete interrect
- set buttonflag 0
-
- }
-
- return
-
- }
- proc mkDiele { } {
- global firstnodex firstnodey
- global secondnodex secondnodey
- global tempnodex tempnodey
- global buttonflag
-
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag newFlag
- global myAppChangedFlag
- global maxga
- checkPal
-
- if { $palFlag < 0 } {
- return $palFlag
- }
-
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
-
- .c config -cursor { cross red white }
- set buttonflag 0
-
- bind .c <Motion> {
-
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $buttonflag == 1 } {
-
- .c delete interrect
- .c create rectangle $tempnodex $tempnodey %x %y -outline blue \
- -tags interrect
- }
- }
-
- bind .c <Button-1> {
-
- if { $buttonflag == 1 } {
- .c delete interrect
- incr dieleCounter
- set diele [.c create rectangle $tempnodex $tempnodey %x %y \
- -outline white -fill black -tags dieleTags$dieleCounter]
- lappend dieleId $diele
- lappend dieleTags dieleTags$dieleCounter
-
- .c lower $diele
- set firstnodex($diele) $tempnodex
- set firstnodey($diele) $tempnodey
- set secondnodex($diele) %x
- set secondnodey($diele) %y
- ## puts $diele
- ## puts $firstnodex($diele)
- ## puts $firstnodey($diele)
- ## puts $secondnodex($diele)
- ## puts $secondnodey($diele)
- set buttonflag 0
-
- set fileHead [lreplace $fileHead 0 0 [expr {[lindex $fileHead 0]+1 }]]
- ## puts $fileHead
-
- lappend dieleData "DIELE"
- lappend dieleData $diele
- lappend dieleData dieleTags$dieleCounter
-
- lappend dieleData $dieleCounter
-
- if { $firstnodex($diele) <= $secondnodex($diele) } {
- set bottomleftX [expr {$firstnodex($diele)/$Xscale+$pbottomleftX }]
- } else {
- set bottomleftX [expr {$secondnodex($diele)/$Xscale+$pbottomleftX }]
- }
-
- if { $firstnodey($diele) >= $secondnodey($diele) } {
- set bottomleftY [expr {($maxYcoord-$firstnodey($diele))/$Yscale+$pbottomleftY }]
- } else {
- set bottomleftY [expr {($maxYcoord-$secondnodey($diele))/$Yscale+$pbottomleftY }]
- }
-
- lappend dieleData $bottomleftX
- lappend dieleData $bottomleftY
-
- lappend dieleData [expr {abs($firstnodex($diele)-$secondnodex($diele))/$Xscale }]
- lappend dieleData [expr {abs($firstnodey($diele)-$secondnodey($diele))/$Yscale }]
-
- if { [expr {1.0/(abs($firstnodey($diele)-$secondnodey($diele))/$Yscale) }] > $maxga } {
-
- set maxga [expr {1.0/(abs($firstnodey($diele)-$secondnodey($diele))/$Yscale) }]
-
- }
-
- lappend dieleData 1.0 ; #permitivity
-
- set myAppChangedFlag 1
-
- ## puts $dieleData
-
- } else {
- set tempnodex %x
- set tempnodey %y
- set buttonflag 1
-
- }
- }
-
- bind .c <Button-3> {
-
- .c delete interrect
- set buttonflag 0
-
- }
-
- return
-
- }
- proc mkGnd { } {
- global firstnodex firstnodey
- global secondnodex secondnodey
- global tempnodex tempnodey
- global buttonflag
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag newFlag
- global myAppChangedFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- .c config -cursor { cross red white }
- set buttonflag 0
-
- bind .c <Motion> {
-
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $buttonflag == 1 } {
-
- .c delete interrect
- .c create rectangle $tempnodex $tempnodey %x %y -outline blue \
- -tags interrect
- }
- }
-
- bind .c <Button-1> {
-
- if { $buttonflag == 1 } {
- .c delete interrect
- incr gndCounter
- set gnd [.c create rectangle $tempnodex $tempnodey %x %y \
- -outline white -fill green -tags gndTags$gndCounter]
- lappend gndId $gnd
-
- lappend gndTags gndTags$gndCounter
- set firstnodex($gnd) $tempnodex
- set firstnodey($gnd) $tempnodey
- set secondnodex($gnd) %x
- set secondnodey($gnd) %y
- ## puts $gnd
- ## puts $firstnodex($gnd)
- ## puts $firstnodey($gnd)
- ## puts $secondnodex($gnd)
- ## puts $secondnodey($gnd)
- set buttonflag 0
-
- set fileHead [lreplace $fileHead 6 6 [expr {[lindex $fileHead 6]+1 }]]
- ## puts $fileHead
-
- lappend gndData "GND"
- lappend gndData $gnd
-
- lappend gndData gndTags$gndCounter
- lappend gndData $gndCounter
-
- if { $firstnodex($gnd) <= $secondnodex($gnd) } {
- set bottomleftX [expr {$firstnodex($gnd)/$Xscale+$pbottomleftX }]
- } else {
- set bottomleftX [expr {$secondnodex($gnd)/$Xscale+$pbottomleftX }]
- }
-
- if { $firstnodey($gnd) >= $secondnodey($gnd) } {
- set bottomleftY [expr {($maxYcoord-$firstnodey($gnd))/$Yscale+$pbottomleftY }]
- } else {
- set bottomleftY [expr {($maxYcoord-$secondnodey($gnd))/$Yscale+$pbottomleftY }]
- }
-
- lappend gndData $bottomleftX
- lappend gndData $bottomleftY
-
- lappend gndData [expr {abs($firstnodex($gnd)-$secondnodex($gnd))/$Xscale }]
- lappend gndData [expr {abs($firstnodey($gnd)-$secondnodey($gnd))/$Yscale }]
-
- set myAppChangedFlag 1
-
- ## puts $gndData
-
- } else {
-
- set tempnodex %x
- set tempnodey %y
- set buttonflag 1
-
- }
- }
-
- bind .c <Button-3> {
-
- .c delete interrect
- set buttonflag 0
- }
-
- return
-
- }
- proc mkTri { } {
- global firstnodex firstnodey
- global secondnodex secondnodey
- global thirdnodex thirdnodey
- global tempnodex tempnodey
- global tempnodex2 tempnodey2
- global buttonflag
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag newFlag
- global myAppChangedFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- .c config -cursor { cross red white }
- set buttonflag 0
- bind .c <Motion> {
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $buttonflag == 1 } {
-
- .c delete interrect
- .c create line $tempnodex $tempnodey %x %y \
- -tags interrect
- } elseif { $buttonflag == 2 } {
- .c delete interrect
- .c create polygon $tempnodex $tempnodey $tempnodex2 $tempnodey2 %x %y \
- -outline blue -tags interrect
- }
- }
-
- bind .c <Button-1> {
-
- if { $buttonflag == 2 } {
- .c delete interrect
- incr triCounter
- set tri [.c create polygon $tempnodex $tempnodey \
- $tempnodex2 $tempnodey2 %x %y \
- -outline black -fill white -tags triTags$triCounter]
- lappend triId $tri
-
- lappend triTags triTags$triCounter
- set firstnodex($tri) $tempnodex
- set firstnodey($tri) $tempnodey
- set secondnodex($tri) $tempnodex2
- set secondnodey($tri) $tempnodey2
- set thirdnodex($tri) %x
- set thirdnodey($tri) %y
- ## puts $tri
- ## puts $firstnodex($tri)
- ## puts $firstnodey($tri)
- ## puts $secondnodex($tri)
- ## puts $secondnodey($tri)
- ## puts $thirdnodex($tri)
- ## puts $thirdnodey($tri)
- set buttonflag 0
-
- set fileHead [lreplace $fileHead 3 3 [expr {[lindex $fileHead 3]+1 }]]
- ## puts $fileHead
-
- lappend triData "TRI"
- lappend triData $tri
- lappend triData triTags$triCounter
- lappend triData $triCounter
-
- lappend triData [expr {$firstnodex($tri)/$Xscale+$pbottomleftX }]
- lappend triData [expr {($maxYcoord-$firstnodey($tri))/$Yscale+$pbottomleftY }]
-
- lappend triData [expr {$secondnodex($tri)/$Xscale+$pbottomleftX }]
- lappend triData [expr {($maxYcoord-$secondnodey($tri))/$Yscale+$pbottomleftY }]
-
- lappend triData [expr {$thirdnodex($tri)/$Xscale+$pbottomleftX }]
- lappend triData [expr {($maxYcoord-$thirdnodey($tri))/$Yscale+$pbottomleftY }]
- set myAppChangedFlag 1
- ## puts $triData
-
- } elseif { $buttonflag == 1 } {
- .c delete interrect
- .c create line $tempnodex $tempnodey %x %y \
- -tags interrect
- set tempnodex2 %x
- set tempnodey2 %y
- set buttonflag 2
- } else {
- set tempnodex %x
- set tempnodey %y
- set buttonflag 1
- }
- }
-
- bind .c <Button-3> {
-
- .c delete interrect
- set buttonflag 0
- }
-
- return
-
- }
- proc mkEll { } {
- global firstnodex firstnodey
- global secondnodex secondnodey
- global tempnodex tempnodey
- global buttonflag
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag newFlag
- global myAppChangedFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- .c config -cursor { cross red white }
- set buttonflag 0
-
- bind .c <Motion> {
-
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $buttonflag == 1 } {
- .c delete interrect
- set majoraxis [expr {sqrt(2)*($tempnodex-%x) }]
- set minoraxis [expr {sqrt(2)*($tempnodey-%y) }]
- .c create oval [expr {$tempnodex-$majoraxis }] [expr {$tempnodey-$minoraxis }] \
- [expr {$tempnodex+$majoraxis }] [expr {$tempnodey+$minoraxis }] \
- -outline blue -tags interrect
- }
- }
-
- bind .c <Button-1> {
-
- if { $buttonflag == 1 } {
- .c delete interrect
- set majoraxis [expr {sqrt(2)*($tempnodex-%x) }]
- set minoraxis [expr {sqrt(2)*($tempnodey-%y) }]
- incr ellCounter
- set ell [.c create oval [expr {$tempnodex-$majoraxis }] [expr {$tempnodey-$minoraxis }] \
- [expr {$tempnodex+$majoraxis }] [expr {$tempnodey+$minoraxis }] \
- -outline black -fill white -tags ellTags$ellCounter]
- lappend ellId $ell
- lappend ellTags ellTags$ellCounter
- set firstnodex($ell) $tempnodex
- set firstnodey($ell) $tempnodey
- set secondnodex($ell) %x
- set secondnodey($ell) %y
- ## puts $ell
- ## puts $firstnodex($ell)
- ## puts $firstnodey($ell)
- ## puts $secondnodex($ell)
- ## puts $secondnodey($ell)
- set buttonflag 0
-
- set fileHead [lreplace $fileHead 4 4 [expr {[lindex $fileHead 4]+1 }]]
- ## puts $fileHead
-
- lappend ellData "ELL"
- lappend ellData $ell
- lappend ellData ellTags$ellCounter
- lappend ellData $ellCounter
-
- lappend ellData [expr {$firstnodex($ell)/$Xscale+$pbottomleftX }]
- lappend ellData [expr {($maxYcoord-$firstnodey($ell))/$Yscale+$pbottomleftY }]
-
- lappend ellData [expr {abs($majoraxis)/$Xscale }]
- lappend ellData [expr {abs($minoraxis)/$Yscale }]
- set myAppChangedFlag 1
- ## puts $ellData
- } else {
- set tempnodex %x
- set tempnodey %y
- set buttonflag 1
- }
- }
-
- bind .c <Button-3> {
- .c delete interrect
- set buttonflag 0
- }
-
- return
-
- }
- proc mkPoly { } {
- global apexnum
- global xcoord ycoord xycoord
- global apexorder
- global tempnodex tempnodey
- global tempnodex2 tempnodey2
- global buttonflag
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag newFlag
- global myAppChangedFlag
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- getApexnumdrop
- set buttonflag 0
- set apexorder 0
- .c config -cursor { cross red white }
-
- bind .c <Motion> {
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- .dummy.statusCon configure -text "x=$realX, y=$realY"
-
- if { $apexorder > 0 && $apexorder < $apexnum } {
- .c delete curside
- .c create line [lindex $xcoord [expr {$apexorder-1 }]] \
- [lindex $ycoord [expr {$apexorder-1 }]] %x %y -tags curside
- }
- }
- bind .c <Button-1> {
- if { $apexorder == 0 } {
- set xcoord %x
- set ycoord %y
- set xycoord %x
- lappend xycoord %y
- incr apexorder
- } elseif { $apexorder > 0 && $apexorder < [expr {$apexnum-1 }] } {
- lappend xcoord %x
- lappend ycoord %y
- lappend xycoord %x
- lappend xycoord %y
- incr apexorder
- .c delete interrect
- set counter 0
- while { $counter < [expr {$apexorder-1 }] } {
- ## puts $counter
- ## puts $apexorder
- ## puts [lindex $xcoord $counter]
- ## puts [lindex $ycoord $counter]
- ## puts [lindex $xcoord [expr {$counter+1 }]]
- ## puts [lindex $ycoord [expr {$counter+1 }]]
- ## puts $xcoord
- ## puts $ycoord
- ## puts $xycoord
-
- .c create line [lindex $xcoord $counter] [lindex $ycoord $counter] \
- [lindex $xcoord [expr {$counter+1 }]] [lindex $ycoord [expr {$counter+1 }]] \
- -tags interrect
- incr counter
- }
-
- } elseif { $apexorder == [expr {$apexnum-1 }] } {
- lappend xcoord %x
- lappend ycoord %y
- lappend xycoord %x
- lappend xycoord %y
- .c delete interrect
- .c delete curside
- incr polyCounter
- set poly [.c create polygon $xycoord -outline white -fill \
- blue -tags polyTags$polyCounter]
- lappend polyId $poly
- lappend polyTags polyTags$polyCounter
- set buttonflag 0
- set apexorder 0
- set fileHead [lreplace $fileHead 5 5 [expr {[lindex $fileHead 5]+1 }]]
- ## puts $fileHead
- lappend polyData "POLY"
- lappend polyData $poly
- lappend polyData polyTags$polyCounter
- lappend polyData $polyCounter
- lappend polyData [expr {[llength $xycoord]/2 }]
- ## puts [llength $xycoord]
- for {set i 0} {$i < [expr {[llength $xycoord]/2 }]} {incr i} {
- lappend polyData [expr {[lindex $xycoord [expr {2*$i }]]/$Xscale+$pbottomleftX }]
- lappend polyData [expr {($maxYcoord-[lindex $xycoord [expr {2*$i+1 }]])/$Yscale \
- +$pbottomleftY }]
- }
- set myAppChangedFlag 1
- ## puts $polyData
- }
- }
- bind .c <Button-3> {
- .c delete interrect
- .c delete curside
- set buttonflag 0
- set apexorder 0
- }
- return
- }
- #########################################################################################
- # Move Unit
- #
- #########################################################################################
- proc moveUnit { } {
- global dieleData recData cirData triData ellData polyData gndData
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global newFlag
- global myAppChangedFlag
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- bind .c <Button-1> {
- if { [lsearch -exact $recId $curPoint] != -1
- || [lsearch -exact $cirId $curPoint] != -1
- || [lsearch -exact $dieleId $curPoint] != -1
- || [lsearch -exact $ellId $curPoint] != -1
- || [lsearch -exact $triId $curPoint] != -1
- || [lsearch -exact $polyId $curPoint] != -1
- || [lsearch -exact $gndId $curPoint] != -1 } {
-
- set curX %x
- set curY %y
- set oriX %x
- set oriY %y
- } else {}
- }
-
- bind .c <B1-Motion> {
- set curPoint [.c find withtag current]
- ## puts $curPoint
-
- if { [lsearch -exact $recId $curPoint] != -1
- || [lsearch -exact $cirId $curPoint] != -1
- || [lsearch -exact $dieleId $curPoint] != -1
- || [lsearch -exact $ellId $curPoint] != -1
- || [lsearch -exact $triId $curPoint] != -1
- || [lsearch -exact $polyId $curPoint] != -1
- || [lsearch -exact $gndId $curPoint] != -1 } {
- ## puts "(%x %y)"
- set realX [expr {%x/$Xscale+$pbottomleftX }]
- set realY [expr {($maxYcoord-%y)/$Yscale+$pbottomleftY }]
- set deltaX [expr {(%x-$oriX)/$Xscale }]
- set deltaY [expr {($oriY-%y)/$Yscale }]
- .dummy.statusCon configure -text "x=$realX, y=$realY, dx=$deltaX, dy=$deltaY"
-
- ## puts $recId
- ## puts [lsearch -exact $recId $curPoint]
-
- if { [lsearch -exact $recId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $recId $curPoint]
- ## puts [lindex $recTags [lsearch -exact $recId $curPoint]]
-
- .c move [lindex $recTags [lsearch -exact $recId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
-
- .c raise [lindex $recTags [lsearch -exact $recId $curPoint]]; #ensure on top of diele
-
- # the data of position should be changed and saved after movement
- set curX %x
- set curY %y
-
- bind .c <ButtonRelease-1> {
- setTag $curPoint $recId $recTags $recData
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
- set recData [lreplace $recData [expr {$curPosition+2 }] [expr {$curPosition+2 }] \
- [expr {[lindex $recData [expr {$curPosition+2 }]]+$xnew }]]
- set recData [lreplace $recData [expr {$curPosition+3 }] [expr {$curPosition+3 }] \
- [expr {[lindex $recData [expr {$curPosition+3 }]]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
-
- } elseif { [lsearch -exact $cirId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $cirId $curPoint]
- ## puts [lindex $cirTags [lsearch -exact $cirId $curPoint]]
-
- .c move [lindex $cirTags [lsearch -exact $cirId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
-
- .c raise [lindex $cirTags [lsearch -exact $cirId $curPoint]]
-
- set curX %x
- set curY %y
-
- bind .c <ButtonRelease-1> {
- setTag $curPoint $cirId $cirTags $cirData
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
- set cirData [lreplace $cirData [expr {$curPosition+2 }] [expr {$curPosition+2 }] \
- [expr {[lindex $cirData [expr {$curPosition+2 }]]+$xnew }]]
- set cirData [lreplace $cirData [expr {$curPosition+3 }] [expr {$curPosition+3 }] \
- [expr {[lindex $cirData [expr {$curPosition+3 }]]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
-
- } elseif { [lsearch -exact $dieleId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $dieleId $curPoint]
- ## puts [lindex $dieleTags [lsearch -exact $dieleId $curPoint]]
-
- .c move [lindex $dieleTags [lsearch -exact $dieleId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
-
- .c lower [lindex $dieleTags [lsearch -exact $dieleId $curPoint]]
-
- set curX %x
- set curY %y
- bind .c <ButtonRelease-1> {
- setTag $curPoint $dieleId $dieleTags $dieleData
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
- set dieleData [lreplace $dieleData [expr {$curPosition+2 }] [expr {$curPosition+2 }] \
- [expr {[lindex $dieleData [expr {$curPosition+2 }]]+$xnew }]]
- set dieleData [lreplace $dieleData [expr {$curPosition+3 }] [expr {$curPosition+3 }] \
- [expr {[lindex $dieleData [expr {$curPosition+3 }]]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
-
- } elseif { [lsearch -exact $ellId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $ellId $curPoint]
- ## puts [lindex $ellTags [lsearch -exact $ellId $curPoint]]
- .c move [lindex $ellTags [lsearch -exact $ellId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
-
- .c raise [lindex $ellTags [lsearch -exact $ellId $curPoint]]
-
- set curX %x
- set curY %y
- bind .c <ButtonRelease-1> {
- setTag $curPoint $ellId $ellTags $ellData
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
- set ellData [lreplace $ellData [expr {$curPosition+2 }] [expr {$curPosition+2 }] \
- [expr {[lindex $ellData [expr {$curPosition+2 }]]+$xnew }]]
- set ellData [lreplace $ellData [expr {$curPosition+3 }] [expr {$curPosition+3 }] \
- [expr {[lindex $ellData [expr {$curPosition+3 }]]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
- } elseif { [lsearch -exact $triId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $triId $curPoint]
- ## puts [lindex $triTags [lsearch -exact $triId $curPoint]]
-
- .c move [lindex $triTags [lsearch -exact $triId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
-
- .c raise [lindex $triTags [lsearch -exact $triId $curPoint]]
-
- set curX %x
- set curY %y
-
- bind .c <ButtonRelease-1> {
- setTag $curPoint $triId $triTags $triData
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
- set triData [lreplace $triData [expr {$curPosition+2 }] [expr {$curPosition+2 }] \
- [expr {[lindex $triData [expr {$curPosition+2 }]]+$xnew }]]
- set triData [lreplace $triData [expr {$curPosition+3 }] [expr {$curPosition+3 }] \
- [expr {[lindex $triData [expr {$curPosition+3 }]]-$ynew }]]
- set triData [lreplace $triData [expr {$curPosition+4 }] [expr {$curPosition+4 }] \
- [expr {[lindex $triData [expr {$curPosition+4 }]]+$xnew }]]
- set triData [lreplace $triData [expr {$curPosition+5 }] [expr {$curPosition+5 }] \
- [expr {[lindex $triData [expr {$curPosition+5 }]]-$ynew }]]
- set triData [lreplace $triData [expr {$curPosition+6 }] [expr {$curPosition+6 }] \
- [expr {[lindex $triData [expr {$curPosition+6 }]]+$xnew }]]
- set triData [lreplace $triData [expr {$curPosition+7 }] [expr {$curPosition+7 }] \
- [expr {[lindex $triData [expr {$curPosition+7 }]]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
-
- } elseif { [lsearch -exact $polyId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $polyId $curPoint]
- ## puts [lindex $polyTags [lsearch -exact $polyId $curPoint]]
- .c move [lindex $polyTags [lsearch -exact $polyId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
- .c raise [lindex $polyTags [lsearch -exact $polyId $curPoint]]
-
- set curX %x
- set curY %y
-
- bind .c <ButtonRelease-1> {
-
- setTag $curPoint $polyId $polyTags $polyData
- set apex [lindex $polyData [expr {$curPosition+2 }]]
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
-
- for {set polycounter 1} {$polycounter<=$apex} {incr polycounter} {
- set tempx [expr {$curPosition+2*$polycounter+1 }]
- set tempy [expr {$curPosition+2*$polycounter+2 }]
- set polyData [lreplace $polyData $tempx $tempx \
- [expr {[lindex $polyData $tempx]+$xnew }]]
- set polyData [lreplace $polyData $tempy $tempy \
- [expr {[lindex $polyData $tempy]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
- }
-
- } elseif { [lsearch -exact $gndId $curPoint] != -1 } {
-
- ## puts [lsearch -exact $gndId $curPoint]
- ## puts [lindex $gndTags [lsearch -exact $gndId $curPoint]]
-
- .c move [lindex $gndTags [lsearch -exact $gndId $curPoint]] \
- [expr {%x-$curX }] [expr {%y-$curY }]
-
- .c raise [lindex $gndTags [lsearch -exact $gndId $curPoint]]
-
- set curX %x
- set curY %y
-
- bind .c <ButtonRelease-1> {
- setTag $curPoint $gndId $gndTags $gndData
- set xnew [expr {(%x-$oriX)/$Xscale }]
- set ynew [expr {(%y-$oriY)/$Yscale }]
- set gndData [lreplace $gndData [expr {$curPosition+2 }] [expr {$curPosition+2 }] \
- [expr {[lindex $gndData [expr {$curPosition+2 }]]+$xnew }]]
- set gndData [lreplace $gndData [expr {$curPosition+3 }] [expr {$curPosition+3 }] \
- [expr {[lindex $gndData [expr {$curPosition+3 }]]-$ynew }]]
- set myAppChangedFlag 1
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
- } else {
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
- } else {
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- }
- }
-
- }
- #########################################################################################
- # Delete Unit
- # correct fileHead xxxxData xxxxCounter
- #########################################################################################
- proc delUnit { } {
- global myAppChangedFlag
- global newFlag
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- bind .c <Button-1> {
- set curPoint [.c find withtag current]
- ## puts $curPoint
- if { [lsearch -exact $recId $curPoint] != -1 } {
- ## puts [lsearch -exact $recId $curPoint]
- ## puts [lindex $recTags [lsearch -exact $recId $curPoint]]
- .c delete [lindex $recTags [lsearch -exact $recId $curPoint]]
- set recData [lreplace $recData [expr {[lsearch -exact $recId $curPoint]*8] \
- [expr {[lsearch -exact $recId $curPoint]*8+7 }]]
- set fileHead [lreplace $fileHead 1 1 [expr {[lindex $fileHead 1]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $recId $curPoint] < [lindex $fileHead 1]} {
- for {set counter [lsearch -exact $recId $curPoint]} \
- {$counter<[lindex $fileHead 1]} {incr counter} {
- set olddata [expr {$counter*8+3 }]
- ## puts $olddata
- set recData [lreplace $recData $olddata $olddata \
- [expr {[lindex $recData $olddata]-1 }]]
- set tempdata [lindex $recData $olddata]
- set recData [lreplace $recData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- recTags$tempdata]
- ## puts $recData
-
- ## puts recTags[expr {$counter+2 }]
- .c addtag recTags[expr {$counter+1 }] withtag recTags[expr {$counter+2 }]
- .c dtag recTags[expr {$counter+2 }]
-
- }
- }
- set recCounter [expr {$recCounter-1 }]
- ## puts $recCounter
-
- set recTags [lreplace $recTags $recCounter $recCounter]
- #delete the last element.
-
- set recId [lreplace $recId [lsearch -exact $recId $curPoint] \
- [lsearch -exact $recId $curPoint]]
-
- ## puts $recTags
- ## puts $recId
- set myAppChangedFlag 1
-
- } elseif { [lsearch -exact $cirId $curPoint] != -1 } {
- ## puts [lsearch -exact $cirId $curPoint]
- ## puts [lindex $cirTags [lsearch -exact $cirId $curPoint]]
- .c delete [lindex $cirTags [lsearch -exact $cirId $curPoint]]
- set cirData [lreplace $cirData [expr {[lsearch -exact $cirId $curPoint]*7] \
- [expr {[lsearch -exact $cirId $curPoint]*7+6 }]]
- set fileHead [lreplace $fileHead 2 2 [expr {[lindex $fileHead 2]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $cirId $curPoint] < [lindex $fileHead 2]} {
- for {set counter [lsearch -exact $cirId $curPoint]} \
- {$counter<[lindex $fileHead 2]} {incr counter} {
- set olddata [expr {$counter*7+3 }]
- ## puts $olddata
- set cirData [lreplace $cirData $olddata $olddata \
- [expr {[lindex $cirData $olddata]-1 }]]
- set tempdata [lindex $cirData $olddata]
- set cirData [lreplace $cirData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- cirTags$tempdata]
- ## puts $cirData
- ## puts cirTags[expr {$counter+2 }]
- .c addtag cirTags[expr {$counter+1 }] withtag cirTags[expr {$counter+2 }]
- .c dtag cirTags[expr {$counter+2 }]
-
- }
- }
- set cirCounter [expr {$cirCounter-1 }]
- ## puts $cirCounter
-
- set cirTags [lreplace $cirTags $cirCounter $cirCounter]
- #delete the last element.
-
- set cirId [lreplace $cirId [lsearch -exact $cirId $curPoint] \
- [lsearch -exact $cirId $curPoint]]
- ## puts $cirTags
- ## puts $cirId
- set myAppChangedFlag 1
- } elseif { [lsearch -exact $dieleId $curPoint] != -1 } {
- ## puts [lsearch -exact $dieleId $curPoint]
- ## puts [lindex $dieleTags [lsearch -exact $dieleId $curPoint]]
- .c delete [lindex $dieleTags [lsearch -exact $dieleId $curPoint]]
- set dieleData [lreplace $dieleData [expr {[lsearch -exact $dieleId $curPoint]*9 }] \
- [expr {[lsearch -exact $dieleId $curPoint]*9+8 }]]
- set fileHead [lreplace $fileHead 0 0 [expr {[lindex $fileHead 0]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $dieleId $curPoint] < [lindex $fileHead 0]} {
- for {set counter [lsearch -exact $dieleId $curPoint]} \
- {$counter<[lindex $fileHead 0]} {incr counter} {
- set olddata [expr {$counter*9+3 }]
- ## puts $olddata
- set dieleData [lreplace $dieleData $olddata $olddata \
- [expr {[lindex $dieleData $olddata]-1 }]]
- set tempdata [lindex $dieleData $olddata }]
- set dieleData [lreplace $dieleData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- dieleTags$tempdata]
- ## puts $dieleData
- ## puts dieleTags[expr {$counter+2 }]
- .c addtag dieleTags[expr {$counter+1 }] withtag dieleTags[expr {$counter+2 }]
- .c dtag dieleTags[expr {$counter+2 }]
-
- }
- }
- set dieleCounter [expr {$dieleCounter-1 }]
- ## puts $dieleCounter
-
- set dieleTags [lreplace $dieleTags $dieleCounter $dieleCounter]
-
- set dieleId [lreplace $dieleId [lsearch -exact $dieleId $curPoint] \
- [lsearch -exact $dieleId $curPoint]]
- ## puts $dieleTags
- ## puts $dieleId
- set myAppChangedFlag 1
- } elseif { [lsearch -exact $ellId $curPoint] != -1 } {
- ## puts [lsearch -exact $ellId $curPoint]
- ## puts [lindex $ellTags [lsearch -exact $ellId $curPoint]]
- .c delete [lindex $ellTags [lsearch -exact $ellId $curPoint]]
- set ellData [lreplace $ellData [expr {[lsearch -exact $ellId $curPoint]*8 }] \
- [expr {[lsearch -exact $ellId $curPoint]*8+7 }]]
- set fileHead [lreplace $fileHead 4 4 [expr {[lindex $fileHead 4]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $ellId $curPoint] < [lindex $fileHead 4]} {
- for {set counter [lsearch -exact $ellId $curPoint]} \
- {$counter<[lindex $fileHead 4]} {incr counter} {
- set olddata [expr {$counter*8+3 }]
- ## puts $olddata
- set ellData [lreplace $ellData $olddata $olddata \
- [expr {[lindex $ellData $olddata]-1 }]]
- set tempdata [lindex $ellData $olddata]
- set ellData [lreplace $ellData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- ellTags$tempdata]
- ## puts $ellData
- ## puts ellTags[expr {$counter+2 }]
- .c addtag ellTags[expr {$counter+1 }] withtag ellTags[expr {$counter+2 }]
- .c dtag ellTags[expr {$counter+2 }]
-
- }
- }
- set ellCounter [expr {$ellCounter-1 }]
- ## puts $ellCounter
-
- set ellTags [lreplace $ellTags $ellCounter $ellCounter]
- set ellId [lreplace $ellId [lsearch -exact $ellId $curPoint] \
- [lsearch -exact $ellId $curPoint]]
- ## puts $ellTagsq
- ## puts $ellId
- set myAppChangedFlag 1
- } elseif { [lsearch -exact $triId $curPoint] != -1 } {
- ## puts [lsearch -exact $triId $curPoint]
- ## puts [lindex $triTags [lsearch -exact $triId $curPoint] }]
- .c delete [lindex $triTags [lsearch -exact $triId $curPoint]]
- set triData [lreplace $triData [expr {[lsearch -exact $triId $curPoint]*10 }] \
- [expr {[lsearch -exact $triId $curPoint]*10+9 }]]
- set fileHead [lreplace $fileHead 3 3 [expr {[lindex $fileHead 3]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $triId $curPoint] < [lindex $fileHead 3]} {
- for {set counter [lsearch -exact $triId $curPoint]} \
- {$counter<[lindex $fileHead 3]} {incr counter} {
- set olddata [expr {$counter*10+3 }]
- ## puts $olddata
- set triData [lreplace $triData $olddata $olddata \
- [expr {[lindex $triData $olddata]-1 }]]
- set tempdata [lindex $triData $olddata]
- set triData [lreplace $triData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- triTags$tempdata]
- ## puts $triData
- ## puts triTags[expr {$counter+2 }]
- .c addtag triTags[expr {$counter+1 }] withtag triTags[expr {$counter+2 }]
- .c dtag triTags[expr {$counter+2 }]
-
- }
- }
- set triCounter [expr {$triCounter-1 }]
- ## puts $triCounter
-
- set triTags [lreplace $triTags $triCounter $triCounter]
- set triId [lreplace $triId [lsearch -exact $triId $curPoint] \
- [lsearch -exact $triId $curPoint]]
- ## puts $triTags
- ## puts $triId
- set myAppChangedFlag 1
- } elseif { [lsearch -exact $polyId $curPoint] != -1 } {
- ## puts [lsearch -exact $polyId $curPoint]
- ## puts [lindex $polyTags [lsearch -exact $polyId $curPoint]]
- .c delete [lindex $polyTags [lsearch -exact $polyId $curPoint]]
- setTag $curPoint $polyId $polyTags $polyData
- set idSite $curPosition
- set curPosition1 $curPosition
- ## puts $idSite
- ## puts [expr {$idSite+2+[lindex $polyData [expr {$idSite+2 }]]*2 }]
- set polyData [lreplace $polyData [expr {$idSite-2 }] [expr {$idSite+2+ \
- [lindex $polyData [expr {$idSite+2 }]]*2 }]]
- ## puts $polyData
- set fileHead [lreplace $fileHead 5 5 [expr {[lindex $fileHead 5]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $polyId $curPoint] < [lindex $fileHead 5]} {
- for {set counter [lsearch -exact $polyId $curPoint]} \
- {$counter<[lindex $fileHead 5]} {incr counter} {
- set olddata [expr {$curPosition1+1 }]
- set polyData [lreplace $polyData $olddata $olddata \
- [expr {[lindex $polyData $olddata]-1 }]]
-
- set tempdata [lindex $polyData $olddata]
- set polyData [lreplace $polyData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- polyTags$tempdata]
- .c addtag polyTags[expr {$counter+1 }] withtag polyTags[expr {$counter+2 }]
- .c dtag polyTags[expr {$counter+2 }]
- set curPosition1 [expr {$curPosition1+5+[lindex $polyData \
- [expr {$curPosition1+2}]]*2}]
- }
- }
- set polyCounter [expr {$polyCounter-1 }]
- ## puts $polyCounter
-
-
- set polyTags [lreplace $polyTags $polyCounter $polyCounter]
- set polyId [lreplace $polyId [lsearch -exact $polyId $curPoint] \
- [lsearch -exact $polyId $curPoint]]
- ## puts $polyData
- ## puts $polyTags
- ## puts $polyId
- set myAppChangedFlag 1
- } elseif { [lsearch -exact $gndId $curPoint] != -1 } {
- ## puts [lsearch -exact $gndId $curPoint]
- ## puts [lindex $gndTags [lsearch -exact $gndId $curPoint]]
- .c delete [lindex $gndTags [lsearch -exact $gndId $curPoint]]
-
- set gndData [lreplace $gndData [expr {[lsearch -exact $gndId $curPoint]*8 }] \
- [expr {[lsearch -exact $gndId $curPoint]*8+7 }]]
- set fileHead [lreplace $fileHead 6 6 [expr {[lindex $fileHead 6]-1 }]]
- ## puts $fileHead
- if {[lsearch -exact $gndId $curPoint] < [lindex $fileHead 6]} {
- for {set counter [lsearch -exact $gndId $curPoint]} \
- {$counter<[lindex $fileHead 6]} {incr counter} {
- set olddata [expr {$counter*8+3 }]
- ## puts $olddata
- set gndData [lreplace $gndData $olddata $olddata \
- [expr {[lindex $gndData $olddata]-1 }]]
- set tempdata [lindex $gndData $olddata]
- set gndData [lreplace $gndData [expr {$olddata-1 }] [expr {$olddata-1 }] \
- gndTags$tempdata]
- ## puts $gndData
- ## puts gndTags[expr {$counter+2 }]
- .c addtag gndTags[expr {$counter+1 }] withtag gndTags[expr {$counter+2 }]
- .c dtag gndTags[expr {$counter+2 }]
-
- }
- }
- set gndCounter [expr {$gndCounter-1 }]
- ## puts $gndCounter
-
- set gndTags [lreplace $gndTags $gndCounter $gndCounter]
- set gndId [lreplace $gndId [lsearch -exact $gndId $curPoint] \
- [lsearch -exact $gndId $curPoint]]
- ## puts $gndTags
- ## puts $gndId
- set myAppChangedFlag 1
- }
- }
- }
- ################################################################################################
- # hand create graphs
- ################################################################################################
- proc dispRect { w title startpoint } {
- global palFlag corFlag newFlag
- global recData
- global rectx recty rectwidth rectheight rectcond
- global startpoint1
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- if { $corFlag == 0 } {
- set rectx [lindex $recData [expr {$startpoint+2 }]]
- set recty [lindex $recData [expr {$startpoint+3 }]]
- set rectwidth [lindex $recData [expr {$startpoint+4 }]]
- set rectheight [lindex $recData [expr {$startpoint+5 }]]
- }
- grid [label $w.top.lab1 -text "LowerLeft X Coord"] \
- [entry $w.top.ent1 -textvariable rectx] -sticky e
- grid [label $w.top.lab2 -text "LowerLeft Y Coord"] \
- [entry $w.top.ent2 -textvariable recty] -sticky e
- grid [label $w.top.lab3 -text "Width"] \
- [entry $w.top.ent3 -textvariable rectwidth] -sticky e
- grid [label $w.top.lab4 -text "Height"] \
- [entry $w.top.ent4 -textvariable rectheight] -sticky e
-
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- if { $corFlag == -1 } {
- rectOk $rectx $recty $rectwidth $rectheight {}
- destroy .rectPara
- } else {
- rectOk $rectx $recty $rectwidth $rectheight $startpoint1
- destroy .rectPara
- }
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .rectPara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc rectOk { rectx recty rectw recth startpoint } {
- global myAppChangedFlag
- global recCounter recId recTags
- global Xscale Yscale
- global maxYcoord
- global pbottomleftX pbottomleftY
- global fileHead recData
- global corFlag
- ## puts "corFlag"
- ## puts $corFlag
- if { $corFlag ==0 } {
- ## puts [lindex $recData [expr {$startpoint }]]
- .c coords [lindex $recData [expr {$startpoint }]] \
- [expr {($rectx-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($recty-$pbottomleftY)*$Yscale }] \
- [expr {($rectx+$rectw-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($recty+$recth-$pbottomleftY)*$Yscale }]
- set recData [lreplace $recData [expr {$startpoint+2 }] [expr {$startpoint+2 }] \
- $rectx]
- set recData [lreplace $recData [expr {$startpoint+3 }] [expr {$startpoint+3 }] \
- $recty]
- set recData [lreplace $recData [expr {$startpoint+4 }] [expr {$startpoint+4 }] \
- $rectw]
- set recData [lreplace $recData [expr {$startpoint+5 }] [expr {$startpoint+5 }] \
- $recth]
- ## puts $recData
- } else {
- incr recCounter
- ## puts [expr {$rectx*$Xscale }]
- ## puts [expr {($maxYcoord-$recty)*$Yscale }]
- ## puts [expr {($rectx+$rectw)*$Xscale }]
- ## puts [expr {$maxYcoord-($recty-$recth)*$Yscale }]
- set rect [.c create rectangle [expr {($rectx-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($recty-$pbottomleftY)*$Yscale }] \
- [expr {($rectx+$rectw-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($recty+$recth-$pbottomleftY)*$Yscale }] \
- -outline white -fill yellow -tags recTags$recCounter]
- lappend recId $rect
- lappend recTags recTags$recCounter
-
- ## puts $recCounter
- ## puts $recId
- ## puts $recTags
-
- set fileHead [lreplace $fileHead 1 1 [expr {[lindex $fileHead 1]+1 }]]
- ## puts $fileHead
-
- lappend recData "REC"
- lappend recData $rect
- lappend recData recTags$recCounter
- lappend recData $recCounter
-
- lappend recData $rectx
- lappend recData $recty
-
- lappend recData $rectw
- lappend recData $recth
- ## puts $recData
- set myAppChangedFlag 1
- }
- }
- proc dispCir { w title startpoint } {
- global palFlag corFlag newFlag
- global cirData
- global circenterX circenterY cirRadius cirCond
- global startpoint1
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- grid [label $w.top.lab1 -text "Center X Coord"] \
- [entry $w.top.ent1 -textvariable circenterX] -sticky e
- grid [label $w.top.lab2 -text "Center Y Coord"] \
- [entry $w.top.ent2 -textvariable circenterY] -sticky e
- grid [label $w.top.lab3 -text "radius"] \
- [entry $w.top.ent3 -textvariable cirRadius] -sticky e
- if { $corFlag == 0 } {
- set circenterX [lindex $cirData [expr {$startpoint+2 }]]
- set circenterY [lindex $cirData [expr {$startpoint+3 }]]
- set cirRadius [lindex $cirData [expr {$startpoint+4 }]]
- }
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- if { $corFlag == -1 } {
- cirOk $circenterX $circenterY $cirRadius {}
- destroy .cirPara
- } else {
- cirOk $circenterX $circenterY $cirRadius $startpoint1
- destroy .cirPara
- }
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .cirPara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc cirOk { cirx ciry cirr startpoint } {
- global myAppChangedFlag
- global cirCounter cirId cirTags
- global Xscale Yscale
- global maxYcoord
- global pbottomleftX pbottomleftY
- global fileHead cirData
- global corFlag
-
- if { $corFlag ==0 } {
- ## puts [lindex $cirData [expr {$startpoint }]]
- .c coords [lindex $cirData [expr {$startpoint }]] \
- [expr {($cirx-$cirr-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($ciry-$cirr-$pbottomleftY)*$Yscale }] \
- [expr {($cirx+$cirr-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($ciry+$cirr-$pbottomleftY)*$Yscale }]
- set cirData [lreplace $cirData [expr {$startpoint+2 }] [expr {$startpoint+2 }] \
- $cirx]
- set cirData [lreplace $cirData [expr {$startpoint+3 }] [expr {$startpoint+3 }] \
- $ciry]
- set cirData [lreplace $cirData [expr {$startpoint+4 }] [expr {$startpoint+4 }] \
- $cirr]
- ## puts $cirData
- } else {
- incr cirCounter
- set cir [.c create oval [expr {($cirx-$cirr-$pbottomleftX)*$Xscale }] [expr {\
- $maxYcoord-($ciry-$cirr-$pbottomleftY)*$Yscale }] \
- [expr {($cirx+$cirr-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($ciry+$cirr-$pbottomleftY)*$Yscale }] \
- -outline white -fill red -tags cirTags$cirCounter]
-
- lappend cirId $cir
- lappend cirTags cirTags$cirCounter
-
- set fileHead [lreplace $fileHead 2 2 [expr {[lindex $fileHead 2]+1 }]]
- ## puts $fileHead
- lappend cirData "CIR"
- lappend cirData $cir
- lappend cirData cirTags$cirCounter
- lappend cirData $cirCounter
- lappend cirData $cirx
- lappend cirData $ciry
- lappend cirData $cirr
-
- ## puts $cirData
- ## puts $cirCounter
- ## puts $cirId
- ## puts $cirTags
- set myAppChangedFlag 1
- }
- }
- proc dispDiele { w title startpoint } {
- global palFlag corFlag newFlag
- global dieleData
- global dieleX dieleY dieleWidth dieleHeight dielePermit dielePermea
- global startpoint1
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- grid [label $w.top.lab1 -text "BottomLeft X Coord"] \
- [entry $w.top.ent1 -textvariable dieleX] -sticky e
- grid [label $w.top.lab2 -text "BottomLeft Y Coord"] \
- [entry $w.top.ent2 -textvariable dieleY] -sticky e
- grid [label $w.top.lab3 -text "Width"] \
- [entry $w.top.ent3 -textvariable dieleWidth] -sticky e
- grid [label $w.top.lab4 -text "Height"] \
- [entry $w.top.ent4 -textvariable dieleHeight] -sticky e
- grid [label $w.top.lab5 -text "Relative Permitivity"] \
- [entry $w.top.ent5 -textvariable dielePermit] -sticky e
-
- if { $corFlag == 0 } {
- set dieleX [lindex $dieleData [expr {$startpoint+2 }]]
- set dieleY [lindex $dieleData [expr {$startpoint+3 }]]
- set dieleWidth [lindex $dieleData [expr {$startpoint+4 }]]
- set dieleHeight [lindex $dieleData [expr {$startpoint+5 }]]
- set dielePermit [lindex $dieleData [expr {$startpoint+6 }]]
- ## puts $dieleData
- }
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- if { $corFlag == -1 } {
- dieleOk $dieleX $dieleY $dieleWidth $dieleHeight $dielePermit {}
- destroy .dielePara
- } else {
- dieleOk $dieleX $dieleY $dieleWidth $dieleHeight $dielePermit \
- $startpoint1
- destroy .dielePara
- }
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .dielePara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc dieleOk { dielex dieley dielew dieleh dielepermit startpoint } {
- global dieleCounter dieleId dieleTags
- global Xscale Yscale
- global maxYcoord
- global dieleData fileHead
- global pbottomleftX pbottomleftY
- global corFlag
- global myAppChangedFlag
- global maxga
- if { $corFlag ==0 } {
- ## puts [lindex $dieleData [expr {$startpoint }]]
- .c coords [lindex $dieleData [expr {$startpoint }]] \
- [expr {($dielex-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($dieley-$pbottomleftY)*$Yscale }] \
- [expr {($dielex+$dielew-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($dieley+$dieleh-$pbottomleftY)*$Yscale }]
- set dieleData [lreplace $dieleData [expr {$startpoint+2 }] [expr {$startpoint+2 }] \
- $dielex]
- set dieleData [lreplace $dieleData [expr {$startpoint+3 }] [expr {$startpoint+3 }] \
- $dieley]
- set dieleData [lreplace $dieleData [expr {$startpoint+4 }] [expr {$startpoint+4 }] \
- $dielew]
- set dieleData [lreplace $dieleData [expr {$startpoint+5 }] [expr {$startpoint+5 }] \
- $dieleh]
- set dieleData [lreplace $dieleData [expr {$startpoint+6 }] [expr {$startpoint+6 }] \
- $dielepermit]
- ## puts $dieleData
- } else {
- incr dieleCounter
- set diele [.c create rectangle [expr {($dielex-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($dieley-$pbottomleftY)*$Yscale }] \
- [expr {($dielex+$dielew-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($dieley+$dieleh-$pbottomleftY)*$Yscale }] \
- -outline white -fill black -tags dieleTags$dieleCounter]
- lappend dieleId $diele
- lappend dieleTags dieleTags$dieleCounter
-
- set fileHead [lreplace $fileHead 0 0 [expr {[lindex $fileHead 0]+1 }]]
- ## puts $fileHead
-
- lappend dieleData "DIELE"
- lappend dieleData $diele
- lappend dieleData dieleTags$dieleCounter
- lappend dieleData $dieleCounter
-
- lappend dieleData $dielex
- lappend dieleData $dieley
-
- lappend dieleData $dielew
- lappend dieleData $dieleh
- if { [expr {1.0/$dieleh }] > $maxga } {
- set maxga [expr {1.0/$dieleh }]
-
- }
-
- lappend dieleData $dielepermit
- set myAppChangedFlag 1
- ## puts $dieleData
-
- ## puts $dieleCounter
- ## puts $dieleId
- ## puts $dieleTags
- }
- }
- proc dispEll { w title startpoint } {
- global palFlag corFlag newFlag
- global ellData
- global ellcenterX ellcenterY ellMajor ellMinor ellCond
- global startpoint1
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- grid [label $w.top.lab1 -text "Center X Coord"] \
- [entry $w.top.ent1 -textvariable ellcenterX] -sticky e
- grid [label $w.top.lab2 -text "Center Y Coord"] \
- [entry $w.top.ent2 -textvariable ellcenterY] -sticky e
- grid [label $w.top.lab3 -text "X Axis Length"] \
- [entry $w.top.ent3 -textvariable ellMajor] -sticky e
- grid [label $w.top.lab4 -text "Y Axis Length"] \
- [entry $w.top.ent4 -textvariable ellMinor] -sticky e
- if { $corFlag == 0 } {
- set ellcenterX [lindex $ellData [expr {$startpoint+2 }]]
- set ellcenterY [lindex $ellData [expr {$startpoint+3 }]]
- set ellMajor [lindex $ellData [expr {$startpoint+4 }]]
- set ellMinor [lindex $ellData [expr {$startpoint+5 }]]
- }
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- if { $corFlag == -1 } {
- ellOk $ellcenterX $ellcenterY $ellMajor $ellMinor {}
- destroy .ellPara
- } else {
- ellOk $ellcenterX $ellcenterY $ellMajor $ellMinor $startpoint1
- destroy .ellPara
- }
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .ellPara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc ellOk { ellx elly ellma ellmi startpoint } {
- global ellCounter ellId ellTags
- global Xscale Yscale
- global maxYcoord
- global fileHead ellData
- global pbottomleftX pbottomleftY
- global corFlag
- global myAppChangedFlag
- if { $corFlag ==0 } {
- ## puts [lindex $ellData [expr {$startpoint }]]
- .c coords [lindex $ellData [expr {$startpoint }]] \
- [expr {($ellx-$ellma-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($elly-$ellmi-$pbottomleftY)*$Yscale }] \
- [expr {($ellx+$ellma-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($elly+$ellmi-$pbottomleftY)*$Yscale }]
- set ellData [lreplace $ellData [expr {$startpoint+2 }] [expr {$startpoint+2 }] \
- $ellx]
- set ellData [lreplace $ellData [expr {$startpoint+3 }] [expr {$startpoint+3 }] \
- $elly]
- set ellData [lreplace $ellData [expr {$startpoint+4 }] [expr {$startpoint+4 }] \
- $ellma]
- set ellData [lreplace $ellData [expr {$startpoint+5 }] [expr {$startpoint+5 }] \
- $ellmi]
- ## puts $ellData
- } else {
- incr ellCounter
- set ell [.c create oval [expr {($ellx-$ellma-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($elly-$ellmi-$pbottomleftY)*$Yscale }] \
- [expr {($ellx+$ellma-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($elly+$ellmi-$pbottomleftY)*$Yscale }] \
- -outline black -fill white -tags ellTags$ellCounter]
-
- lappend ellId $ell
- lappend ellTags ellTags$ellCounter
- set fileHead [lreplace $fileHead 4 4 [expr {[lindex $fileHead 4]+1 }]]
- ## puts $fileHead
- lappend ellData "ELL"
- lappend ellData $ell
- lappend ellData ellTags$ellCounter
- lappend ellData $ellCounter
- lappend ellData $ellx
- lappend ellData $elly
- lappend ellData $ellma
- lappend ellData $ellmi
- set myAppChangedFlag 1
- ## puts $ellData
- ## puts $ellCounter
- ## puts $ellId
- ## puts $ellTags
- }
- }
- proc dispTri { w title startpoint } {
- global palFlag corFlag newFlag
- global triData
- global triapex1X triapex1Y triapex2X triapex2Y triapex3X triapex3Y triCond
- global startpoint1
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- grid [label $w.top.lab1 -text "Apex 1 X Coord"] \
- [entry $w.top.ent1 -textvariable triapex1X] -sticky e
- grid [label $w.top.lab2 -text "Apex 1 Y Coord"] \
- [entry $w.top.ent2 -textvariable triapex1Y] -sticky e
- grid [label $w.top.lab3 -text "Apex 2 X Coord"] \
- [entry $w.top.ent3 -textvariable triapex2X] -sticky e
- grid [label $w.top.lab4 -text "Apex 2 Y Coord"] \
- [entry $w.top.ent4 -textvariable triapex2Y] -sticky e
- grid [label $w.top.lab5 -text "Apex 3 X Coord"] \
- [entry $w.top.ent5 -textvariable triapex3X] -sticky e
- grid [label $w.top.lab6 -text "Apex 3 Y Coord"] \
- [entry $w.top.ent6 -textvariable triapex3Y] -sticky e
- if { $corFlag == 0 } {
- set triapex1X [lindex $triData [expr {$startpoint+2 }]]
- set triapex1Y [lindex $triData [expr {$startpoint+3 }]]
- set triapex2X [lindex $triData [expr {$startpoint+4 }]]
- set triapex2Y [lindex $triData [expr {$startpoint+5 }]]
- set triapex3X [lindex $triData [expr {$startpoint+6 }]]
- set triapex3Y [lindex $triData [expr {$startpoint+7 }]]
- }
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- if { $corFlag == -1 } {
- triOk $triapex1X $triapex1Y $triapex2X $triapex2Y $triapex3X $triapex3Y {}
- destroy .triPara
- } else {
- triOk $triapex1X $triapex1Y $triapex2X $triapex2Y $triapex3X $triapex3Y $startpoint1
- destroy .triPara
- }
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .triPara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc triOk { tri1x tri1y tri2x tri2y tri3x tri3y startpoint } {
- global triCounter triId triTags
- global Xscale Yscale
- global maxYcoord
- global fileHead triData
- global pbottomleftX pbottomleftY
- global corFlag
- global myAppChangedFlag
- if { $corFlag ==0 } {
- ## puts [lindex $triData [expr {$startpoint }]]
- .c coords [lindex $triData [expr {$startpoint }]] \
- [expr {($tri1x-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($tri1y-$pbottomleftY)*$Yscale }] \
- [expr {($tri2x-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($tri2y-$pbottomleftY)*$Yscale }] \
- [expr {($tri3x-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($tri3y-$pbottomleftY)*$Yscale }]
- set triData [lreplace $triData [expr {$startpoint+2 }] [expr {$startpoint+2 }] \
- $tri1x]
- set triData [lreplace $triData [expr {$startpoint+3 }] [expr {$startpoint+3 }] \
- $tri1y]
- set triData [lreplace $triData [expr {$startpoint+4 }] [expr {$startpoint+4 }] \
- $tri2x]
- set triData [lreplace $triData [expr {$startpoint+5 }] [expr {$startpoint+5 }] \
- $tri2y]
- set triData [lreplace $triData [expr {$startpoint+6 }] [expr {$startpoint+6 }] \
- $tri3x]
- set triData [lreplace $triData [expr {$startpoint+7 }] [expr {$startpoint+7 }] \
- $tri3y]
- ## puts $triData
- } else {
- incr triCounter
- set tri [.c create polygon [expr {($tri1x-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($tri1y-$pbottomleftY)*$Yscale }] \
- [expr {($tri2x-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($tri2y-$pbottomleftY)*$Yscale }] \
- [expr {($tri3x-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($tri3y-$pbottomleftY)*$Yscale }] \
- -outline white -fill white -tags triTags$triCounter]
-
- lappend triId $tri
- lappend triTags triTags$triCounter
-
- set fileHead [lreplace $fileHead 3 3 [expr {[lindex $fileHead 3]+1 }]]
- ## puts $fileHead
-
- lappend triData "TRI"
- lappend triData $tri
- lappend triData triTags$triCounter
- lappend triData $triCounter
-
- lappend triData $tri1x
- lappend triData $tri1y
-
- lappend triData $tri2x
- lappend triData $tri2y
-
- lappend triData $tri3x
- lappend triData $tri3y
-
- set myAppChangedFlag 1
-
- ## puts $triData
-
- ## puts $triCounter
- ## puts $triId
- ## puts $triTags
- }
- }
- proc getApexnumdrop { } {
- global apexnum
- set apexnum 4
- return $apexnum
- }
- proc getApexnum { } {
- global apexnum
- set apexnum1 4
- dispPoly .polyPara { Polygon Conductor Parameters } $apexnum1 {}
- return $apexnum1
- }
- proc dispPoly { w title apexnum startpoint } {
- global palFlag corFlag newFlag
- global pbottomleftX pbottomleftY
- global startpoint1
- global polyCounter polyId polyTags
- global Xscale Yscale
- global maxYcoord
- global apexpoly
- global polyData
- global polyapexX1 polyapexY1 polyapexX2 polyapexY2 polyapexX3 polyapexY3
- global polyapexX4 polyapexY4 polyapexX5 polyapexY5 polyapexX6 polyapexY6
- global polyapexX7 polyapexY7 polyapexX8 polyapexY8 polyapexX9 polyapexY9
- global polyapexX10 polyapexY10 polyapexX11 polyapexY11 polyapexX12 polyapexY12
- global polyapexX13 polyapexY13 polyapexX14 polyapexY14 polyapexX15 polyapexY15
- global polyapexX16 polyapexY16 polyapexX17 polyapexY17 polyapexX18 polyapexY18
- global polyapexX19 polyapexY19 polyapexX20 polyapexY20
- global polyCond
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- set counter 1
- set polyapexlist {}
- set apexpoly $apexnum
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- while { $counter <= $apexnum } {
-
- global polyapexX polyapexY
- ## puts $counter
- grid [label $w.top.lab[expr {2*$counter }] -text "Apex$counter X Coord"] \
- [entry $w.top.ent[expr {2*$counter }] -textvariable polyapexX($counter)] \
- -sticky e
- grid [label $w.top.lab[expr {2*$counter+1 }] -text "Apex$counter Y Coord"] \
- [entry $w.top.ent[expr {2*$counter+1 }] -textvariable polyapexY($counter)] -sticky e
- incr counter
- }
- if { $corFlag == 0 } {
- for {set counter 1} {$counter<=$apexnum} {incr counter} {
- set polyapexX($counter) [lindex $polyData [expr {$startpoint+2*$counter+1 }]]
- set polyapexY($counter) [lindex $polyData [expr {$startpoint+2*$counter+2 }]]
- }
- }
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- set polyapexlist [expr {($polyapexX(1)-$pbottomleftX)*$Xscale }]
- lappend polyapexlist [expr {$maxYcoord-($polyapexY(1)-$pbottomleftY)*$Yscale }]
- for {set counter 2} {$counter<=$apexpoly} {incr counter} {
- lappend polyapexlist [expr {($polyapexX($counter)-$pbottomleftX)*$Xscale }]
- lappend polyapexlist [expr {$maxYcoord-($polyapexY($counter)-$pbottomleftY)*$Yscale }]
- }
- ## puts $polyapexlist
- if { $corFlag == -1 } {
- polyOk $polyapexlist {}
- } else {
- polyOk $polyapexlist $startpoint1
- }
- destroy .polyPara
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .polyPara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc polyOk { polyapexlist startpoint } {
- global polyCounter polyId polyTags
- global Xscale Yscale
- global fileHead polyData
- global paletteYsize
- global pbottomleftX pbottomleftY
- global maxYcoord
- global corFlag
- global myAppChangedFlag
- if { $corFlag ==0 } {
- ## puts [lindex $polyData [expr {$startpoint }]]
- .c coords [lindex $polyData [expr {$startpoint }]] $polyapexlist
- for {set i 0} {$i < [expr {[llength $polyapexlist]/2 }]} {incr i} {
- set polyData [lreplace $polyData [expr {$startpoint+3+2*$i }] \
- [expr {$startpoint+3+2*$i }] \
- [expr {[lindex $polyapexlist [expr {2*$i }]]/$Xscale+$pbottomleftX }]]
- set polyData [lreplace $polyData [expr {$startpoint+4+2*$i }] \
- [expr {$startpoint+4+2*$i }] \
- [expr {($maxYcoord-[lindex $polyapexlist \
- [expr {2*$i+1 }]])/$Yscale+$pbottomleftY }]]
- }
- ## puts $polyData
- } else {
- incr polyCounter
- set poly [.c create polygon $polyapexlist \
- -outline white -fill blue -tags polyTags$polyCounter]
- lappend polyId $poly
- lappend polyTags polyTags$polyCounter
-
- set fileHead [lreplace $fileHead 5 5 [expr {[lindex $fileHead 5]+1 }]]
- ## puts $fileHead
-
- lappend polyData "POLY"
- lappend polyData $poly
- lappend polyData polyTags$polyCounter
- lappend polyData $polyCounter
-
- lappend polyData [expr {[llength $polyapexlist]/2 }]
-
- ## puts [llength $polyapexlist]
-
- for {set i 0} {$i < [expr {[llength $polyapexlist]/2 }]} {incr i} {
- lappend polyData [expr {[lindex $polyapexlist [expr {2*$i }]]/$Xscale+$pbottomleftX }]
- lappend polyData [expr {($maxYcoord-[lindex $polyapexlist \
- [expr {2*$i+1 }]])/$Yscale+$pbottomleftY }]
- }
- set myAppChangedFlag 1
-
- ## puts $polyData
-
- ## puts $polyCounter
- ## puts $polyId
- ## puts $polyTags
- }
- }
- proc dispGnd { w title startpoint } {
- global palFlag corFlag newFlag
- global gndX gndY gndWidth gndHeight gndCond
- global gndData
- global startpoint1
- checkPal
- if { $palFlag < 0 } {
- return $palFlag
- }
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- grid [label $w.top.lab1 -text "LowerLeft X Coord"] \
- [entry $w.top.ent1 -textvariable gndX] -sticky e
- grid [label $w.top.lab2 -text "LowerLeft Y Coord"] \
- [entry $w.top.ent2 -textvariable gndY] -sticky e
- grid [label $w.top.lab3 -text "Width"] \
- [entry $w.top.ent3 -textvariable gndWidth] -sticky e
- grid [label $w.top.lab4 -text "Height"] \
- [entry $w.top.ent4 -textvariable gndHeight] -sticky e
- if { $corFlag == 0 } {
- set gndX [lindex $gndData [expr {$startpoint+2 }]]
- set gndY [lindex $gndData [expr {$startpoint+3 }]]
- set gndWidth [lindex $gndData [expr {$startpoint+4 }]]
- set gndHeight [lindex $gndData [expr {$startpoint+5 }]]
- }
-
- set startpoint1 $startpoint
- button $w.bot.buttonok -text "OK" -command {
- if { $corFlag == -1 } {
- gndOk $gndX $gndY $gndWidth $gndHeight {}
- destroy .gndPara
- } else {
- gndOk $gndX $gndY $gndWidth $gndHeight $startpoint1
- destroy .gndPara
- }
- }
- button $w.bot.buttoncancel -text "CANCEL" -command { destroy .gndPara }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc gndOk { gndx gndy gndw gndh startpoint } {
- global gndCounter gndId gndTags
- global Xscale Yscale
- global maxYcoord
- global fileHead gndData
- global pbottomleftX pbottomleftY
- global corFlag
- global myAppChangedFlag
- if { $corFlag ==0 } {
- ## puts [lindex $gndData [expr {$startpoint }]]
- .c coords [lindex $gndData [expr {$startpoint }]] \
- [expr {($gndx-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($gndy-$pbottomleftY)*$Yscale }] \
- [expr {($gndx+$gndw-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($gndy+$gndh-$pbottomleftY)*$Yscale }]
- set gndData [lreplace $gndData [expr {$startpoint+2 }] [expr {$startpoint+2 }] \
- $gndx]
- set gndData [lreplace $gndData [expr {$startpoint+3 }] [expr {$startpoint+3 }] \
- $gndy]
- set gndData [lreplace $gndData [expr {$startpoint+4 }] [expr {$startpoint+4 }] \
- $gndw]
- set gndData [lreplace $gndData [expr {$startpoint+5 }] [expr {$startpoint+5 }] \
- $gndh]
- # set gndData [lreplace $gndData [expr {$startpoint+6 }] [expr {$startpoint+6 }] \
- $gndc]
- ## puts $gndData
- } else {
- incr gndCounter
-
- ## puts $Xscale
- ## puts $Yscale
- set gnd [.c create rectangle [expr {($gndx-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($gndy-$pbottomleftY)*$Yscale }] \
- [expr {($gndx+$gndw-$pbottomleftX)*$Xscale }] \
- [expr {$maxYcoord-($gndy+$gndh-$pbottomleftY)*$Yscale }] \
- -outline white -fill green -tags gndTags$gndCounter]
-
- lappend gndId $gnd
- lappend gndTags gndTags$gndCounter
-
- set fileHead [lreplace $fileHead 6 6 [expr {[lindex $fileHead 6]+1 }]]
- ## puts $fileHead
-
- lappend gndData "GND"
- lappend gndData $gnd
- lappend gndData gndTags$gndCounter
- lappend gndData $gndCounter
-
- lappend gndData $gndx
- lappend gndData $gndy
-
- lappend gndData $gndw
- lappend gndData $gndh
-
- # lappend gndData $gndc
- set myAppChangedFlag 1
- ## puts $gndData
- ## puts $gndCounter
- ## puts $gndId
- ## puts $gndTags
- }
- }
- ########################################################################################
- # Edit the parameters of the palette
- ########################################################################################
- proc Coption { w title flag } {
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global tempdata1 tempdata2 tempdata3 tempdata4
- global newFlag
- if { $newFlag < 0 && $flag == 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
-
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- set tempdata1 $paletteXsize
- set tempdata2 $paletteYsize
- set tempdata3 $pbottomleftX
- set tempdata4 $pbottomleftY
- grid [label $w.top.lab3 -text "Palette Size"] \
- [entry $w.top.ent2 -textvariable paletteXsize] \
- [label $w.top.lab4 -text "m"] -sticky e
- grid [label $w.top.lab5 -text "Palette Bottomleft X Coord"] \
- [entry $w.top.ent3 -textvariable pbottomleftX] -sticky e
- grid [label $w.top.lab6 -text "Palette Bottomleft Y Coord"] \
- [entry $w.top.ent4 -textvariable pbottomleftY] -sticky e
- button $w.bot.buttonok -text "OK" -command {
- set paletteYsize [expr {$paletteXsize/$maxXcoord*$maxYcoord }]
- destroy .palettePara
- optionOk
- }
- button $w.bot.buttoncancel -text "CANCEL" -command {
- destroy .palettePara
- set paletteXsize $tempdata1
- set paletteYsize $tempdata2
- set pbottomleftX $tempdata3
- set pbottomleftY $tempdata4
- }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- proc optionOk { } {
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag
- global myAppChangedFlag
-
- if { $paletteXsize > 0 && $paletteYsize > 0 } {
- set Xscale [ expr {$maxXcoord/$paletteXsize }]
- ## puts "begin"
- ## puts $maxXcoord
- ## puts $paletteXsize
- ## puts $Xscale
- ## puts "end"
- set Yscale [ expr {$maxYcoord/$paletteYsize }]
- set palFlag 0
- ## puts "OK"
- }
-
- }
- proc calpara { w title } {
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global tempdata1 tempdata2 tempdata3 tempdata4
- global tempdata5 tempdata6 tempdata7 tempdata8
- global tempdata9 tempdata10 tempdata11 tempdata12
- global newFlag
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- # global freq sigma
- global od maxga
- global myAppChangedFlag
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- toplevel $w -class Dialog
- wm title $w $title
- wm iconname $w Dialog
- frame $w.top -relief raised -bd 1
- pack $w.top -side top -fill both
- frame $w.bot -relief raised -bd 1
- pack $w.bot -side bottom -fill both
- set tempdata1 $Nh
- set tempdata2 $Nit
- set tempdata3 $J
- set tempdata4 $Nwx
- set tempdata5 $Nwy
- set tempdata6 $Nws
- set tempdata7 $Np
- set tempdata8 $Eps
- set tempdata9 $matr
- set tempdata10 $od
- set tempdata11 $maxga
- grid [label $w.top.lab3 -text "Wavelet Point Number"] \
- [entry $w.top.ent2 -textvariable Nh] -sticky e
- grid [label $w.top.lab4 -text "Number of Iteration"] \
- [entry $w.top.ent3 -textvariable Nit] -sticky e
- grid [label $w.top.lab5 -text "Resolution Level"] \
- [entry $w.top.ent4 -textvariable J] -sticky e
- grid [label $w.top.lab6 -text "Gauss Quadrature X"] \
- [entry $w.top.ent5 -textvariable Nwx] -sticky e
- grid [label $w.top.lab7 -text "Gauss Quadrature Y"] \
- [entry $w.top.ent6 -textvariable Nwy] -sticky e
- grid [label $w.top.lab8 -text "Number of Segments/Wavelet"] \
- [entry $w.top.ent7 -textvariable Nws] -sticky e
- grid [label $w.top.lab9 -text "OPQ Seperation"] \
- [entry $w.top.ent8 -textvariable Np] -sticky e
- grid [label $w.top.lab10 -text "STAB Accuracy"] \
- [entry $w.top.ent9 -textvariable Eps] -sticky e
- grid [label $w.top.lab11 -text "Matrix Solution"] \
- [entry $w.top.ent10 -textvariable matr] -sticky e
- grid [label $w.top.lab12 -text "Order of appoximation"] \
- [entry $w.top.ent11 -textvariable od] -sticky e
- grid [label $w.top.lab13 -text "Maximum approximation range"] \
- [entry $w.top.ent12 -textvariable maxga] -sticky e
- button $w.bot.buttonok -text "OK" -command {
- set myAppChangedFlag 1
- destroy .calPara
- }
- button $w.bot.buttoncancel -text "CANCEL" -command {
- destroy .calPara
- set Nh $tempdata1
- set Nit $tempdata2
- set J $tempdata3
- set Nwx $tempdata4
- set Nwy $tempdata5
- set Nws $tempdata6
- set Np $tempdata7
- set Eps $tempdata8
- set matr $tempdata9
- set od $tempdata10
- set maxga $tempdata11
- }
- pack $w.bot.buttonok $w.bot.buttoncancel -side left -fill both
- }
- ########################################################################################
- # Check if the palette parameters have been setup
- ########################################################################################
- proc checkPal { } {
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global palFlag
-
- if { $paletteXsize > 0 && $paletteYsize > 0 } {
- set palFlag 0
- } else {
- set palFlag -1
- toplevel .prompted -class Dialog
- wm title .prompted "error"
- wm iconname .prompted Dialog
- frame .prompted.top -relief raised -bd 1
- pack .prompted.top -side top -fill both
- message .prompted.msg -width 8c -justify left -relief flat -bd 2 \
- -text "You must input the palette parameters first."
- button .prompted.okbutton -text "OK" -command { destroy .prompted }
- pack .prompted.msg .prompted.okbutton -side top -padx 2m -pady 2m
- }
- return $palFlag
- }
- proc promptInfo { message } {
- toplevel .prompted -class Dialog -width 400
- wm title .prompted "Info"
- wm iconname .prompted Dialog
- frame .prompted.top -relief raised -bd 1
- pack .prompted.top -side top -expand yes -fill both
- puts "message: $message"
- set txt [text .prompted.msg -width 40]
- $txt insert end $message
- ## message .prompted.msg -anchor c -relief flat -bd 2 \
- ## -text $message
- button .prompted.okbutton -text "OK" -command { destroy .prompted }
- pack .prompted.msg .prompted.okbutton -side top -expand yes -fill x
- }
- ########################################################################################
- # Update data package after deleting and adding new components
- ########################################################################################
- proc updateData { } {
-
- }
- ########################################################################################
- #--------------------------------------------------
- #
- # File Procedures
- #
- # Note that opening, saving, and closing files
- # are all intertwined. This code assumes that
- # new/open/close/exit may lose some data.
- #
- #--------------------------------------------------
- global myAppFileTypes
- set myAppFileName ""
- set myAppChangedFlag 0
- set myAppFileTypes {
- {{data files} {.dat} }
- {{tcl files} {.tcl .tk} }
- {{text files} {.txt} }
- {{All Files} * }
- }
- proc myAppFileNew { } {
- global myAppFileName
- global myAppChangedFlag
- global myAppFileTypes
- global newFlag
- global palFlag
- global paletteXsize paletteYsize
-
- myAppFileClose
-
- set filename [ tk_getSaveFile -filetypes $myAppFileTypes \
- -initialdir "."]
- ## puts "file: $filename"
- if {$filename != ""} {
- set indx [string first ".dat" $filename]
- if { $indx > -1 } {
- set myAppFileName [string range $filename 0 [expr {($indx - 1) }]]
- } else {
- set myAppFileName $filename
- }
- }
- Coption .palettePara { Palette Parameters } 1
- tkwait window .palettePara
- if { $palFlag == 0 } {
- initc 0
- .c configure -background gray
- .dummy.statusCon configure -text "Your have setup a new file named tempfile"
-
- set newFlag 0
- set myAppFileName ""
- set myAppChangedFlag 0
- }
- }
- proc myAppFileOpen { {filename ""} } {
- global myAppFileName
- global myAppChangedFlag
- global myAppFileTypes
- global fileHead
- global dieleData recData cirData triData ellData polyData gndData
- global recCounter cirCounter dieleCounter ellCounter triCounter polyCounter \
- gndCounter
- global recTags cirTags dieleTags ellTags triTags polyTags gndTags
- global recId cirId dieleId ellId triId polyId gndId
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global newFlag
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- global od maxga
-
- myAppFileClose
- if {$filename == ""} {
- set filename [tk_getOpenFile -filetypes $myAppFileTypes]
- }
-
- if {$filename != ""} {
- set indx [string first ".dat" $filename]
- if { $indx > -1 } {
- set myAppFileName [string range $filename 0 [expr {($indx - 1) }]]
- } else {
- set myAppFileName $filename
- }
- puts "Open: $myAppFileName.dat"
- if { [catch {open $filename r} fp] } {
- error "Cannot Open File $filename for Reading"
- } else {
- #--------------------------------------------------
- # insert code for "open" operation
- #--------------------------------------------------
- ### .t insert end [read $fp [file size $filename]]
- # need to read the data, redraw them on the palette and
- # renew the Id number in xxxID and xxxData, renew counter.
- # So just redraw all of them
-
- set newFlag 0
- .c configure -background gray
- gets $fp paletteXsize
- gets $fp paletteYsize
- gets $fp Xscale
- gets $fp Yscale
- gets $fp pbottomleftX
- gets $fp pbottomleftY
-
- gets $fp Nh
- gets $fp Nit
- gets $fp J
- gets $fp Nwx
- gets $fp Nwy
- gets $fp Nws
- gets $fp Np
- gets $fp Eps
- gets $fp matr
- gets $fp od
- gets $fp maxga
- gets $fp tempfileHead
-
- gets $fp tempdieleData
- gets $fp temprecData
- gets $fp tempcirData
- gets $fp temptriData
- gets $fp tempellData
- gets $fp temppolyData
- gets $fp tempgndData
-
- set curNum [lindex $tempfileHead 0]
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- set dielex [lindex $tempdieleData [expr {$counter*9+4 }]]
- set dieley [lindex $tempdieleData [expr {$counter*9+5 }]]
- set dielew [lindex $tempdieleData [expr {$counter*9+6 }]]
- set dieleh [lindex $tempdieleData [expr {$counter*9+7 }]]
- set dielepermit [lindex $tempdieleData [expr {$counter*9+8 }]]
- dieleOk $dielex $dieley $dielew $dieleh $dielepermit {}
- }
- set curNum [lindex $tempfileHead 1]
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- set recx [lindex $temprecData [expr {$counter*8+4 }]]
- set recy [lindex $temprecData [expr {$counter*8+5 }]]
- set recw [lindex $temprecData [expr {$counter*8+6 }]]
- set rech [lindex $temprecData [expr {$counter*8+7 }]]
- rectOk $recx $recy $recw $rech {}
- }
- puts "circle: $tempcirData"
- set curNum [lindex $tempfileHead 2]
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- set cirx [lindex $tempcirData [expr {$counter*7+4 }]]
- set ciry [lindex $tempcirData [expr {$counter*7+5 }]]
- set cirr [lindex $tempcirData [expr {$counter*7+6 }]]
- puts "circle: ($cirx,$ciry) $cirr"
- cirOk $cirx $ciry $cirr {}
- }
- set curNum [lindex $tempfileHead 3]
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- set tri1x [lindex $temptriData [expr {$counter*10+4 }]]
- set tri1y [lindex $temptriData [expr {$counter*10+5 }]]
- set tri2x [lindex $temptriData [expr {$counter*10+6 }]]
- set tri2y [lindex $temptriData [expr {$counter*10+7 }]]
- set tri3x [lindex $temptriData [expr {$counter*10+8 }]]
- set tri3y [lindex $temptriData [expr {$counter*10+9 }]]
- triOk $tri1x $tri1y $tri2x $tri2y $tri3x $tri3y {}
- }
- set curNum [lindex $tempfileHead 4]
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- set ellx [lindex $tempellData [expr {$counter*8+4 }]]
- set elly [lindex $tempellData [expr {$counter*8+5 }]]
- set ellma [lindex $tempellData [expr {$counter*8+6 }]]
- set ellmi [lindex $tempellData [expr {$counter*8+7 }]]
- ellOk $ellx $elly $ellma $ellmi {}
- }
- set curNum [lindex $tempfileHead 5]
- ## puts "tempfileHead: $tempfileHead $curNum"
- ## puts "temppolyData: $temppolyData"
- if {$curNum > 0} {
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- if { [lsearch $temppolyData POLY] == 0 } {
- ## puts "hhh"
- set tempapexnum [lindex $temppolyData 4]
- ## puts $tempapexnum
- set tempapex {}
- for { set i 1 } { $i <= $tempapexnum } {incr i} {
- lappend tempapex [expr {([lindex $temppolyData [expr {3+2*$i }]] \
- -$pbottomleftX)*$Xscale }]
- lappend tempapex [expr {$maxYcoord-([lindex $temppolyData \
- [expr {4+2*$i }]]-$pbottomleftY)*$Yscale }]
- }
- }
- #---------------------------------------------------------------------
- # Fix so more than one polygon can be read into the program. skz (2/19/2002)
- #---------------------------------------------------------------------
- #### set temppolyData [lreplace $temppolyData 0 [expr {5+2*$tempapexnum }]]
- set temppolyData [string range $temppolyData 4 [expr { [string length $temppolyData] - 1 }]]
- set indx [string first POLY $temppolyData]
- if { $indx > 0 } {
- set temppolyData [string range $temppolyData $indx [expr { [string length $temppolyData] - 1 }]]
- }
- ## puts $tempapex
- ## puts $temppolyData
- puts "tempapex: $tempapex"
- polyOk $tempapex {}
- }
- }
- set curNum [lindex $tempfileHead 6]
- for {set counter 0} {$counter < $curNum} {incr counter} {
- set corFlag -1
- set gndx [lindex $tempgndData [expr {$counter*8+4 }]]
- set gndy [lindex $tempgndData [expr {$counter*8+5 }]]
- set gndw [lindex $tempgndData [expr {$counter*8+6 }]]
- set gndh [lindex $tempgndData [expr {$counter*8+7 }]]
- gndOk $gndx $gndy $gndw $gndh {}
- }
- }
- close $fp
- ## set myAppFileName $filename
- set myAppChangedFlag 0
- }
- }
- proc myAppFileClose { } {
- global myAppFileName
- global myAppChangedFlag
- if { $myAppChangedFlag } {
- myAppPromptForSave
- }
- delall
- initc 1
- .c configure -background black
- #--------------------------------------------------
- # insert code for "close" operation
- #--------------------------------------------------
- ### .t delete 1.0 end
- set myAppFileName ""
- set myAppChangedFlag 0
- }
- proc myAppFileSave { {filename ""} } {
- global myAppFileName
- global myAppFileTypes
- global myAppChangedFlag
- global fileHead
- global dieleData recData cirData triData ellData polyData gndData
- global recCounter cirCounter dieleCounter ellCounter triCounter polyCounter \
- gndCounter
- global recTags cirTags dieleTags ellTags triTags polyTags gndTags
- global recId cirId dieleId ellId triId polyId gndId
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- global od maxga
- if { $filename == "" && $myAppFileName != "" } {
- set filename $myAppFileName
- } elseif { $filename == "" && $myAppFileName == "" } {
- set filename [tk_getSaveFile -filetypes $myAppFileTypes]
- if { $filename != "" } {
- set myAppFileName $filename
- }
- }
- puts "Save: $myAppFileName.in"
- if { $filename != "" } {
- set fullfilename [format "%s.in" $myAppFileName]
- if { [catch {open $filename w+ } fp] } {
- error "Cannot write to $filename"
- }
- puts $fp $paletteXsize
- puts $fp $paletteYsize
- puts $fp $Xscale
- puts $fp $Yscale
- puts $fp $pbottomleftX
- puts $fp $pbottomleftY
- puts $fp $Nh
- puts $fp $Nit
- puts $fp $J
- puts $fp $Nwx
- puts $fp $Nwy
- puts $fp $Nws
- puts $fp $Np
- puts $fp $Eps
- puts $fp $matr
- puts $fp $od
- puts $fp $maxga
- puts $fp $fileHead
- puts $fp $dieleData
- puts $fp $recData
- puts $fp $cirData
- puts $fp $triData
- puts $fp $ellData
- puts $fp $polyData
- puts $fp $gndData
- #--------------------------------------------------
- # insert code for "save" operation
- #--------------------------------------------------
- ### puts -nonewline [.t get 1.0 end]
- close $fp
- set myAppFileName $filename
- set myAppChangedFlag 0
- }
- }
- proc myAppFileSaveAs { } {
- global myAppFileTypes
- set filename [tk_getSaveFile -filetypes $myAppFileTypes]
- if { $filename != "" } {
- set myAppFileName $filename
- myAppFileSave $filename
- }
- }
- proc myAppPromptForSave { } {
-
- set answer [tk_messageBox -title "save?" -type yesno -icon question -message "Do you want to save the changes?"]
-
- if { $answer == "yes" } {
- myAppFileSaveAs
- }
-
- }
- proc myAppExit { } {
- myAppFileClose
- exit
- }
- #########################################################################
- # NAME: about
- # PURPOSE: show the about information including name and version
- #
- #########################################################################
- proc about {} {
- # tk_messageBox -message "Muti-conductor Parameters Computation \n Electric Packaging Lab.\n Arizona State University\n 2000.8"
- promptInfo " Capacitance Calculation of\n Multiconductor Lines \n\n\n Copyright 2001.05 EPL\n Electric Packaging Lab.\nElectrical Engineering Dept. \n Arizona State University\n\n 2001.05"
- }
- proc viewreadme {} {
- exec emacs readme &
- }
- proc eplIntro {} {
- promptInfo "This program is developed by\n\n Electric Packaging Lab\n Eletrical Engineering Dept. \n Arizona State University \n\n Tel: (480)965-7048\n http://quantum.eas.asu.edu\n"
- }
- proc printPara {} {
-
- global newFlag
- global pData
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
-
- setdata
- ## puts $pData
- exec lpr <<$pData &
- }
- proc printcal {} {
-
- global newFlag
- global pcal
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
-
- caldata
- ## puts $pcal
- exec lpr <<$pcal &
- }
- proc printGraph {} {
- global myAppFileName
- global maxXcoord maxYcoord
- set pssurfix ".ps"
- if { $myAppFileName != "" } {
- set pssurfix $myAppFileName$pssurfix
- } else {
- promptInfo "You must save the palette first!"
- return -1
- }
- .c create rectangle 0 0 [expr {$maxXcoord-1 }] [expr {$maxYcoord-1 }] \
- -outline black -tags printframe
- set psFlag [.c postscript -width 24c -height 16c -colormode gray -file $pssurfix -rotate 1]
- .c delete printframe
- if { $psFlag == "" } {
- exec lpr $pssurfix &
- } else {
- promptInfo "The Postscript file can not be generated!"
- return -1
- }
- }
- proc setTag { id idArray tagArray dataArray } {
- global curPosition
- set tempPosition [lsearch -exact $idArray $id]
- set tempTag [lindex $tagArray $tempPosition]
- set curPosition [lsearch -exact $dataArray $tempTag]
- return $curPosition
- }
- ##############################################
- # Test
- ##############################################
- proc startcal1 { flag } {
- global env
- global fileHead
- global myAppFileName
- global dieleData recData cirData triData ellData polyData gndData
- global newFlag
- global pData pcal
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- global od maxga
- ## puts "newFlag $newFlag"
- ## puts "hhh"
- if { $newFlag < 0 } {
- promptInfo "You must setup a new palette first!"
- return $newFlag
- }
- set fileId [ open "$myAppFileName.in" w+ ]
- set gndnumber [lindex $fileHead 6]
- set recnumber [lindex $fileHead 1]
- set cirnumber [lindex $fileHead 2]
- set tranumber [lindex $fileHead 5]
- set dienumber [lindex $fileHead 0]; # number of dielectric layers
- puts $fileId $gndnumber
- puts $fileId $recnumber
- puts $fileId $cirnumber
- puts $fileId $tranumber
- puts $fileId $dienumber; #
- if { $gndnumber > 0 } {
- for { set i 1 } { $i <= $gndnumber } {incr i} {
- puts $fileId [lindex $gndData [expr {($i-1)*8+4 }]]
- puts $fileId [lindex $gndData [expr {($i-1)*8+5 }]]
- puts $fileId [lindex $gndData [expr {($i-1)*8+6 }]]
- puts $fileId [lindex $gndData [expr {($i-1)*8+7 }]]
- }
- }
- if { $recnumber > 0 } {
- for { set i 1 } { $i <= $recnumber } {incr i} {
- puts $fileId [lindex $recData [expr {($i-1)*8+4 }]]
- puts $fileId [lindex $recData [expr {($i-1)*8+5 }]]
- puts $fileId [lindex $recData [expr {($i-1)*8+6 }]]
- puts $fileId [lindex $recData [expr {($i-1)*8+7 }]]
- }
- }
- if { $cirnumber > 0 } {
- for { set i 1 } { $i <= $cirnumber } {incr i} {
- puts $fileId [lindex $cirData [expr {($i-1)*7+4 }]]
- puts $fileId [lindex $cirData [expr {($i-1)*7+5 }]]
- puts $fileId [lindex $cirData [expr {($i-1)*7+6 }]]
- }
- }
- if { $tranumber > 0 } {
- for { set i 1 } { $i <= $tranumber } {incr i} {
- puts $fileId [lindex $polyData [expr {($i-1)*13+5 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+6 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+7 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+8 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+9 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+10 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+11 }]]
- puts $fileId [lindex $polyData [expr {($i-1)*13+12 }]]
- }
- }
- if { $dienumber > 0 } {
- for { set i 1 } { $i <= $dienumber } {incr i} {
- puts $fileId [lindex $dieleData [expr {($i-1)*9+4 }]]
- puts $fileId [lindex $dieleData [expr {($i-1)*9+5 }]]
- puts $fileId [lindex $dieleData [expr {($i-1)*9+6 }]]
- puts $fileId [lindex $dieleData [expr {($i-1)*9+7 }]]
- puts $fileId [lindex $dieleData [expr {($i-1)*9+8 }]]
- }
- }
- puts $fileId $Nh
- puts $fileId $Nit
- puts $fileId $J
- puts $fileId $Nwx
- puts $fileId $Nwy
- puts $fileId $Nws
- puts $fileId $Np
- puts $fileId $Eps
- puts $fileId $matr
- puts $fileId $od
- puts $fileId $maxga
- close $fileId
- ## puts $flag
- if {$flag == 1} {
- setdata
- caldata
- #set fp [ open "/users/zhichao/tcltk/cal/caldata.sys" w+ ]
- set fp [ open "caldata.sys" w+ ]
- puts $fp $pData
- puts $fp $pcal
- close $fp
- #exec xemacs "/users/zhichao/tcltk/cal/caldata.sys" &
- exec emacs "caldata.sys" &
- } elseif {$flag == 2} {
- #---------------------------------------------------------
- # Change the cursor to a watch and run calcCAP.exe
- #---------------------------------------------------------
- set cursr [.c cget -cursor]
- .mbar configure -cursor watch
- .c configure -cursor watch
- update
- set hd [catch { eval exec $env(CALCCAP_LIBRARY)/calcCAP \
- $myAppFileName} result]
- puts $result
- #---------------------------------------------------------
- # Change the curso back to the normal cursor.
- #---------------------------------------------------------
- .mbar configure -cursor $cursr
- .c configure -cursor $cursr
- update
- checkResult
- }
- }
- proc checkResult { } {
- global myAppFileName
- #exec xemacs /users/zhichao/tcltk/cal/data.out &
- eval exec emacs $myAppFileName.out &
- }
- proc killpro { hd } {
- global pid
- toplevel .apexwindow -class Dialog
- wm title .apexwindow "Calculation"
- wm iconname .apexwindow Dialog
- frame .apexwindow.textframe -width 10c -height 6c
- frame .apexwindow.buttonframe -width 10c -height 2c
- label .apexwindow.textframe.label -text "In Calculation, Please wait..."
- set pid $hd
- button .apexwindow.buttonframe.bbutton -text Break -command {
- exec kill -9 $pid
- destroy .apexwindow
- }
- pack .apexwindow.textframe .apexwindow.buttonframe -side top -padx 1m -pady 2m
- pack .apexwindow.textframe.label -side left -padx 1m -pady 2m
- pack .apexwindow.buttonframe.bbutton \
- -side left -padx 1m -pady 2m
- }
- proc setdata { } {
- global fileHead
- global dieleData recData cirData triData ellData polyData gndData
- global newFlag
- global pData
-
- set gndnumber [lindex $fileHead 6]
- set recnumber [lindex $fileHead 1]
- set cirnumber [lindex $fileHead 2]
- set tranumber [lindex $fileHead 5]
- set dienumber [lindex $fileHead 0]
- set nl "\n"
- set sp " "
- set sp1 " "
- set sp5 " "
- set sep " -------------------------------------"
- set hh " The Geometrical Parameters"
- set dn " Dielectric Number:"
- set gn " Ground Number:"
- set rn " Rectangle Number:"
- set cn " Circle Number:"
- set tn " Trapezoid Number:"
- set h0 " DIELETRIC"
- set h1 " GROUND PLANE"
- set h2 " RECTANGLE"
- set h3 " CIRCLE"
- set h4 " TRAPEZOID"
-
- set r1 " lowerleft x:"
- set r2 " lowerleft y:"
- set r3 " width:"
- set r4 " height:"
-
- set c1 " center x:"
- set c2 " center y:"
- set c3 " radius:"
- set t1 " apex x"
- set t2 " apex y"
- set t3 ":"
- set c " current:"
- set er " epsr:"
- set pData $nl$sep$nl$hh$nl$sep$nl$nl
- set pData $pData$dn$sp$dienumber$nl$nl
- set pData $pData$gn$sp$gndnumber$nl
- set pData $pData$rn$sp$recnumber$nl
- set pData $pData$cn$sp$cirnumber$nl
- set pData $pData$tn$sp$tranumber$nl$nl$sep$nl
- if { $dienumber > 0 } {
- for { set i 1 } { $i <= $dienumber } { incr i } {
- set pData $pData$h0$i$nl$nl
- set pData $pData$r1$sp[lindex $dieleData [expr {($i-1)*9+4 }]]$nl
- set pData $pData$r2$sp[lindex $dieleData [expr {($i-1)*9+5 }]]$nl
- set pData $pData$r3$sp[lindex $dieleData [expr {($i-1)*9+6 }]]$nl
- set pData $pData$r4$sp[lindex $dieleData [expr {($i-1)*9+7 }]]$nl
- set pData $pData$sp5$er$sp[lindex $dieleData [expr {($i-1)*9+8 }]]$nl
- set pData $pData$nl
- }
- set pData $pData$sep$nl
- }
-
- if { $gndnumber > 0 } {
- for { set i 1 } { $i <= $gndnumber } { incr i } {
- set pData $pData$h1$i$nl$nl
- set pData $pData$r1$sp[lindex $gndData [expr {($i-1)*8+4 }]]$nl
- set pData $pData$r2$sp[lindex $gndData [expr {($i-1)*8+5 }]]$nl
- set pData $pData$r3$sp[lindex $gndData [expr {($i-1)*8+6 }]]$nl
- set pData $pData$r4$sp[lindex $gndData [expr {($i-1)*8+7 }]]$nl
- #set pData $pData$sp5$c$sp[lindex $gndData [expr {($i-1)*9+8 }]]$nl
- set pData $pData$nl
- }
- set pData $pData$sep$nl
- }
- if { $recnumber > 0 } {
- for { set i 1 } { $i <= $recnumber } { incr i } {
- set pData $pData$h2$i$nl$nl
- set pData $pData$r1$sp[lindex $recData [expr {($i-1)*8+4 }]]$nl
- set pData $pData$r2$sp[lindex $recData [expr {($i-1)*8+5 }]]$nl
- set pData $pData$r3$sp[lindex $recData [expr {($i-1)*8+6 }]]$nl
- set pData $pData$r4$sp[lindex $recData [expr {($i-1)*8+7 }]]$nl
- #set pData $pData$sp5$c$sp[lindex $recData [expr {($i-1)*9+8 }]]$nl
- set pData $pData$nl
- }
- set pData $pData$sep$nl
- }
- if { $cirnumber > 0 } {
- for { set i 1 } { $i <= $cirnumber } { incr i } {
- set pData $pData$h3$i$nl$nl
- set pData $pData$c1$sp[lindex $cirData [expr {($i-1)*7+4 }]]$nl
- set pData $pData$c2$sp[lindex $cirData [expr {($i-1)*7+5 }]]$nl
- set pData $pData$c3$sp[lindex $cirData [expr {($i-1)*7+6 }]]$nl
- #set pData $pData$sp1$c$sp[lindex $cirData [expr {($i-1)*8+7 }]]$nl
- set pData $pData$nl
- }
- set pData $pData$sep$nl
- }
- if { $tranumber > 0 } {
- for { set i 1 } { $i <= $tranumber } { incr i } {
- set pData $pData$h4$i$nl$nl
- for { set j 1 } { $j <= 4 } { incr j } {
- set pData $pData$t1[expr {$j }]$t3$sp[lindex $polyData [expr {($i-1)*13+3+$j*2 }]]$nl
- set pData $pData$t2[expr {$j }]$t3$sp[lindex $polyData [expr {($i-1)*13+4+$j*2 }]]$nl
- }
- #set pData $pData$c$sp[lindex $polyData [expr {($i-1)*14+13 }]]$nl
- set pData $pData$nl
- }
- }
-
- }
- proc caldata { } {
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- global od maxga
- global pcal
- set t1 " Wavelet Point Number:"
- set t2 " Number of Iteration:"
- set t3 " Resolution Level:"
- set t4 " Gauss Quadrature X:"
- set t5 " Gauss Quadrature Y:"
- set t6 " \# of Segments/Wavelet:"
- set t7 " OPQ Seperation:"
- set t8 " STAB Accuracy:"
- set t9 " Matrix Solution:"
- set t10 " Order of Approximation"
- set t11 " Approximation Range"
- set nl "\n"
- set sp " "
- set sep " -------------------------------------"
- set hh " The Calculation Parameters"
- set pcal $nl$sep$nl$hh$nl$sep$nl$nl
- set pcal $pcal$t1$sp$Nh$nl
- set pcal $pcal$t2$sp$Nit$nl
- set pcal $pcal$t3$sp$J$nl
- set pcal $pcal$t4$sp$Nwx$nl
- set pcal $pcal$t5$sp$Nwy$nl
- set pcal $pcal$t6$sp$Nws$nl
- set pcal $pcal$t7$sp$Np$nl
- set pcal $pcal$t8$sp$Eps$nl
- set pcal $pcal$t9$sp$matr$nl
- set pcal $pcal$t10$sp$od$nl
- set pcal $pcal$t11$sp$maxga$nl
- }
- proc delall { } {
-
- global fileHead
- global recTags cirTags dieleTags ellTags triTags polyTags gndTags
- set gndnumber [lindex $fileHead 6]
- set recnumber [lindex $fileHead 1]
- set cirnumber [lindex $fileHead 2]
- set tranumber [lindex $fileHead 5]
- set dienumber [lindex $fileHead 0]
- if { $dienumber > 0 } {
- for { set i 0 } { $i < $dienumber } {incr i} {
- .c delete [lindex $dieleTags $i]
- }
- }
-
- if { $gndnumber > 0 } {
- for { set i 0 } { $i < $gndnumber } {incr i} {
- .c delete [lindex $gndTags $i]
- }
- }
-
- if { $recnumber > 0 } {
- for { set i 0 } { $i < $recnumber } {incr i} {
- .c delete [lindex $recTags $i]
- }
- }
-
- if { $cirnumber > 0 } {
- for { set i 0 } { $i < $cirnumber } {incr i} {
- .c delete [lindex $cirTags $i]
- }
- }
-
- if { $tranumber > 0 } {
- for { set i 0 } { $i < $tranumber } {incr i} {
- .c delete [lindex $polyTags $i]
- }
- }
- }
- proc initc { flag } {
- global fileHead;# the number of each kind of conductor and dielectric
-
- global dieleData recData cirData triData ellData polyData gndData
- # global variables for saving all parameters of each kind
- global palFlag
- global corFlag
- global newFlag
- global recCounter cirCounter dieleCounter ellCounter triCounter polyCounter \
- gndCounter
- global recTags cirTags dieleTags ellTags triTags polyTags gndTags
- global recId cirId dieleId ellId triId polyId gndId
-
- global maxXcoord maxYcoord
- global paletteXsize paletteYsize Xscale Yscale
- global pbottomleftX pbottomleftY
- global Nh Nit J
- global Nwx Nwy Nws
- global Np Eps matr
- global od maxga
- global pData pcal
-
- set fileHead { 0 0 0 0 0 0 0 }; # dieleNum recNum cirNum triNum ellNum polyNum gndNum
- set corFlag -1
- set newFlag -1
- set recCounter 0
- set cirCounter 0
- set dieleCounter 0
- set ellCounter 0
- set triCounter 0
- set polyCounter 0
- set gndCounter 0
- set recId ""
- set cirId ""
- set dieleId ""
- set ellId ""
- set triId ""
- set polyId ""
- set gndId ""
- set recData ""
- set cirData ""
- set dieleData ""
- set ellData ""
- set triData ""
- set polyData ""
- set gndData ""
- set recTags ""
- set cirTags ""
- set dieleTags ""
- set ellTags ""
- set triTags ""
- set polyTags ""
- set gndTags ""
-
- set pData ""
- set pcal ""
-
- set maxXcoord 879.00000
- set maxYcoord 586.00000
- if { $flag == 1 } {
- set paletteXsize 0
- set paletteYsize 0
- set pbottomleftX 0
- set pbottomleftY 0
-
- set palFlag -1
- set Xscale 0
- set Yscale 0
-
- }
-
- set Nh 1024
- set Nit 40
- set J 6
-
- set Nwx 8
- set Nwy 10
- set Nws 5
- set Np 0.0
- set Eps 1.0e-5
- set matr 2
-
- set od 5
- set maxga 0
- bind .c <Button-1> { }
- bind .c <B1-Motion> { }
- bind .c <ButtonRelease-1> { }
- bind .c <Motion> { }
-
- }
- proc main { argc argv } {
- global myAppFileName
- global_init
- if { $argc == 1 } {
- set myAppFileName [lindex $argv 0]
- puts "file: $myAppFileName.dat"
- myAppFileOpen $myAppFileName.dat
- }
- }
- main $argc $argv
|