DIRECTORY ImagerBasic, Imager USING [Context, CurveTo, LineTo, MoveTo, MaskStroke, MaskStrokeClosed, MaskFill, Trajectory, MaskVector, SetColor, white, DoSave, SetXY, Trans], FitIO, FitStateUtils, FitBasic USING[SampleHandle, SListHandle, Handle, LinkHandle, TrajHandle], FitState USING [Handle, GetClosed], Complex USING [Vec, Mul], Cubic USING [Bezier], Vector USING [Unit], Rope USING [ROPE], IO USING [STREAM, Close, Put, real, char, int, rope, SP, CR]; FitIOImpl: CEDAR PROGRAM IMPORTS Imager, IO, Complex, Vector, FitStateUtils, FitState EXPORTS FitIO = { OPEN FitIO; Handle: TYPE = FitState.Handle; SetFeedback: PUBLIC PROC[ctx: Context, feedback: Feedback] = { ctx.feedback _ feedback; IF ctx.logActions THEN { --print feedback SELECT feedback.color FROM Imager.white => PrintRope[ctx, "white "]; ENDCASE=> PrintRope[ctx, "black"]; PrintLine[ctx, "FB.color"]; PrintReal[ctx, feedback.sampleSize]; PrintLine[ctx, "Fit.sampleSize"]; PrintReal[ctx, feedback.jointSize]; PrintLine[ctx, "Fit.jointSize"]; PrintReal[ctx, feedback.nodeLength]; PrintLine[ctx, "Fit.nodeLength"]; PrintReal[ctx, feedback.nodeLineWidth]; PrintLine[ctx, "Fit.nodeLineWidth"]; PrintReal[ctx, feedback.lineWidth]; PrintLine[ctx, "Fit.lineWidth"]; }; }; DrawSamples: PUBLIC PROC [ctx: Context, handle: Handle, all: BOOLEAN _ FALSE, fill: BOOLEAN _ FALSE] = { list: LIST OF Imager.Trajectory; traj: Imager.Trajectory _ PathFromSList[ctx, handle.slist]; IF traj=NIL THEN RETURN ELSE list _ CONS[traj,list]; Imager.SetColor[ctx.imager, ctx.feedback.color]; IF all THEN { makeList: FitStateUtils.SListProc = {list _ CONS[PathFromSList[ctx, slist],list]}; FitStateUtils.ForAllOtherSLists[handle,makeList]; }; IF fill THEN MaskFill[ctx,list] ELSE IF FitState.GetClosed[handle] THEN MaskStrokeClosed[ctx,list] ELSE MaskStroke[ctx,list]; IF ctx.logActions THEN PrintLine[ctx, "\n"]; }; DrawContour: PUBLIC PROC [ctx: Context, handle: Handle, all: BOOLEAN _ FALSE, fill: BOOLEAN _ FALSE] = { traj: Imager.Trajectory _ PathFromTraj[ctx, handle.traj]; list: LIST OF Imager.Trajectory; IF traj=NIL THEN RETURN ELSE list _ CONS[traj,list]; Imager.SetColor[ctx.imager, ctx.feedback.color]; IF all THEN { makeList: FitStateUtils.TrajProc = {list _ CONS[PathFromTraj[ctx, traj, fill],list]}; FitStateUtils.ForAllOtherTrajs[handle,makeList]; }; IF fill THEN MaskFill[ctx, list] ELSE IF FitState.GetClosed[handle] OR all THEN MaskStrokeClosed[ctx, list] ELSE MaskStroke[ctx, list]; IF ctx.logActions THEN PrintLine[ctx, "\n"]; }; DrawCubic: PUBLIC PROC[ctx: Context, cubic: Cubic.Bezier] = { list: LIST OF Imager.Trajectory; traj: Imager.Trajectory _ MoveTo[ctx, cubic.b0]; traj _ CurveTo[ctx, traj,cubic.b1,cubic.b2,cubic.b3]; MaskStroke[ctx, CONS[traj,list]]; }; PathFromSList: PROC [ctx: Context, slist: FitBasic.SListHandle] RETURNS [path: Imager.Trajectory] = { first: BOOLEAN _ TRUE; do: FitStateUtils.SampleProc = { IF first THEN {path _ MoveTo[ctx, s.xy]; first _ FALSE} ELSE path_ LineTo[ctx, path,s.xy]; }; FitStateUtils.ForAllSamples[slist, do]; IF ctx.logActions AND path#NIL THEN PrintLine[ctx, "\n"]; RETURN[path]; }; PathFromTraj: PROC [ctx: Context, traj: FitBasic.TrajHandle, moveToNext: BOOLEAN _ FALSE] RETURNS [path: Imager.Trajectory] = { first: BOOLEAN _ TRUE; do: FitStateUtils.LinkProc = { IF first THEN {path _ MoveTo[ctx, l.cubic.b0, moveToNext]; first _ FALSE}; path _ CurveTo[ctx, path,l.cubic.b1,l.cubic.b2,l.cubic.b3]; }; FitStateUtils.ForAllLinks[traj, do]; IF ctx.logActions AND path#NIL THEN PrintLine[ctx, "\n"]; }; MarkSamples: PUBLIC PROC [ctx: Context, handle: Handle, all: BOOLEAN _ FALSE] = { markSample: FitStateUtils.SampleProc = {MarkSample[ctx, s]}; markSamples: FitStateUtils.SListProc = {FitStateUtils.ForAllSamples[slist, markSample]}; [] _ markSamples[handle.slist]; IF all THEN FitStateUtils.ForAllOtherSLists[handle, markSamples]; IF ctx.logActions THEN PrintLine[ctx, "\n"]; }; MarkNodes: PUBLIC PROC [ctx: Context, handle: Handle, all: BOOLEAN _ FALSE] = { markNode: FitStateUtils.SampleProc = {MarkNode[ctx, s]}; markNodes: FitStateUtils.SListProc = {FitStateUtils.ForAllSamples[slist, markNode]}; [] _ markNodes[handle.slist]; IF all THEN FitStateUtils.ForAllOtherSLists[handle, markNodes]; IF ctx.logActions THEN PrintLine[ctx, "\n"]; }; MarkJoints: PUBLIC PROC [ctx: Context, handle: Handle, all: BOOLEAN _ FALSE] ={ --joints between the cubic pieces do: FitStateUtils.TrajProc = {MarkTrajJoints[ctx, traj]}; [] _ MarkTrajJoints[ctx, handle.traj]; IF all THEN FitStateUtils.ForAllOtherTrajs[handle, do]; IF ctx.logActions THEN PrintLine[ctx, "\n"]; }; MarkTrajJoints: PROC[ctx: Context, traj: FitBasic.TrajHandle] = { first: BOOLEAN _ TRUE; do: FitStateUtils.LinkProc = { IF first THEN {MarkJoint[ctx, l.cubic.b0]; first _ FALSE}; MarkJoint[ctx, l.cubic.b3]; }; FitStateUtils.ForAllLinks[traj, do]; IF ctx.logActions THEN PrintLine[ctx, "\n"]; }; MarkNode: PUBLIC PROC [ctx: Context, s: FitBasic.SampleHandle] = { pt: Complex.Vec _ MagnifyPoint[ctx, s.xy]; drawProc: PROC = { drawTan: PROC[t: Complex.Vec, d: REAL] = { t _ Complex.Mul[Vector.Unit[t],[0,d]]; IF t = [0,0] THEN { --draw a box w: REAL _ d/2.0; path: Imager.Trajectory _ Imager.MoveTo[[-w,-w]]; path _ Imager.LineTo[path, [-w,w]]; path _ Imager.LineTo[path, [w,w]]; path _ Imager.LineTo[path, [w,-w]]; Imager.MaskStrokeClosed[ctx.imager,path]; } ELSE { --draw a line Imager.MaskVector[ctx.imager, [-t.x,-t.y], [t.x,t.y], ctx.feedback.nodeLineWidth]; }; }; Imager.SetXY[ctx.imager,[pt.x,pt.y]]; Imager.Trans[ctx.imager]; drawTan[t: s.tanIn, d: ctx.feedback.nodeLength]; drawTan[t: s.tanOut, d: ctx.feedback.nodeLength*1.5]; IF s.jointType=forced THEN { --draw diamond dot w: REAL _ ctx.feedback.nodeLength/2.0; path: Imager.Trajectory _ Imager.MoveTo[[-w, 0]]; path _ Imager.LineTo[path, [0,w]]; path _ Imager.LineTo[path, [w,0]]; path _ Imager.LineTo[path, [0,-w]]; Imager.MaskStrokeClosed[ctx.imager,path]; Imager.MaskFill[ctx.imager,path]; }; }; IF s.jointType=none THEN RETURN; Imager.DoSave[ctx.imager, drawProc]; IF ctx.logActions THEN { PrintPoint[ctx, pt]; PrintPoint[ctx, s.tanIn]; PrintPoint[ctx, s.tanOut]; IF s.jointType=forced THEN PrintRope[ctx, "Fit.forcedJoint "] ELSE PrintRope[ctx, "Fit.joint "]; }; }; MarkSample: PUBLIC PROC [ctx: Context, s: FitBasic.SampleHandle] = { size: REAL _ ctx.feedback.sampleSize; pt: Complex.Vec _ MagnifyPoint[ctx, s.xy]; traj: Imager.Trajectory _ Imager.MoveTo[[0,0]]; draw: PROC = { Imager.SetXY[ctx.imager,[pt.x,pt.y]]; Imager.Trans[ctx.imager]; Imager.MaskStroke[ctx.imager,traj, size, round]; }; traj _ Imager.LineTo[traj,[0,0]]; Imager.DoSave[ctx.imager, draw]; IF ctx.logActions THEN {PrintPoint[ctx, pt]; PrintRope[ctx, "Fit.mark "]}; }; MarkJoint: PUBLIC PROC[ctx: Context, pt: Complex.Vec] = { size: REAL _ ctx.feedback.jointSize; traj: Imager.Trajectory; pt _ MagnifyPoint[ctx, pt]; traj _ Imager.MoveTo[[pt.x, pt.y]]; traj _ Imager.LineTo[traj,[pt.x, pt.y]]; Imager.MaskStroke[ctx.imager,traj, size, round]; IF ctx.logActions THEN {PrintPoint[ctx, pt]; PrintRope[ctx, "Fit.joint "]}; }; MoveTo: PROC[ctx: Context, p: Complex.Vec, moveToNext: BOOLEAN _ FALSE] RETURNS [path: Imager.Trajectory]= { p _ MagnifyPoint[ctx, p]; path _ Imager.MoveTo[[p.x,p.y]]; IF ctx.logActions THEN { PrintPoint[ctx, p]; IF moveToNext THEN PrintRope[ctx, "Fit.movetonext "] ELSE PrintRope[ctx, "Fit.moveto "]}; RETURN[path]; }; LineTo: PROC[ctx: Context, path: Imager.Trajectory, p: Complex.Vec] RETURNS [Imager.Trajectory]= { p _ MagnifyPoint[ctx, p]; path _ Imager.LineTo[path, [p.x,p.y]]; IF ctx.logActions THEN {PrintPoint[ctx, p]; PrintRope[ctx, "Fit.lineto "]}; RETURN[path]; }; CurveTo: PROC[ctx: Context, path: Imager.Trajectory, p1,p2,p3: Complex.Vec] RETURNS [Imager.Trajectory] = { p1 _ MagnifyPoint[ctx, p1]; p2 _ MagnifyPoint[ctx, p2]; p3 _ MagnifyPoint[ctx, p3]; path _ Imager.CurveTo[path,[p1.x,p1.y],[p2.x,p2.y],[p3.x,p3.y]]; IF ctx.logActions THEN { PrintPoint[ctx, p1]; PrintPoint[ctx, p2]; PrintPoint[ctx, p3]; PrintLine[ctx, "Fit.curveto "]; }; RETURN[path]; }; MaskStroke: PROC[ctx: Context, list: LIST OF Imager.Trajectory] = { width: REAL _ ctx.feedback.lineWidth; count: INT _ 0; FOR l: LIST OF Imager.Trajectory _ list, l.rest UNTIL l=NIL DO Imager.MaskStroke[ctx.imager,l.first,width]; count _ count+1; ENDLOOP; IF ctx.logActions THEN {PrintInt[ctx, count]; PrintLine[ctx, "Fit.maskstroke"]}; }; MaskStrokeClosed: PROC[ctx: Context, list: LIST OF Imager.Trajectory] = { width: REAL _ ctx.feedback.lineWidth; count: INT _ 0; FOR l: LIST OF Imager.Trajectory _ list, l.rest UNTIL l=NIL DO Imager.MaskStrokeClosed[ctx.imager,l.first,width]; count _ count+1; ENDLOOP; IF ctx.logActions THEN {PrintInt[ctx, count]; PrintLine[ctx, "Fit.maskstrokeclosed"]}; }; MaskFill: PROC[ctx: Context, list: LIST OF Imager.Trajectory] = { Imager.MaskFill[ctx.imager,list]; IF ctx.logActions THEN { count: INT _ 0; FOR l: LIST OF Imager.Trajectory _ list, l.rest UNTIL l=NIL DO count _ count+1; ENDLOOP; PrintInt[ctx, count]; PrintLine[ctx, "Fit.maskfill"]; }; }; NoLog: PUBLIC SIGNAL = CODE; StartLog: PUBLIC PROC [ctx: Context, stream: IO.STREAM _ NIL] = { IF ctx.log#NIL THEN IO.Close[ctx.log]; ctx.log _ stream; ctx.logActions _ TRUE; }; StopLog: PUBLIC PROC[ctx: Context, close: BOOLEAN _ TRUE] = { IF close THEN IO.Close[ctx.log]; ctx.logActions _ FALSE; }; PrintReal: PROC[ctx: Context, r: REAL] = {OPEN IO; Put[ctx.log,real[r],char[SP]]}; PrintRope: PROC[ctx: Context, s: Rope.ROPE] = {OPEN IO; Put[ctx.log,rope[s]]}; PrintLine: PROC[ctx: Context, s: Rope.ROPE] = {OPEN IO; Put[ctx.log,rope[s],char[CR]]}; PrintInt: PROC[ctx: Context, i: INT] = {OPEN IO; Put[ctx.log,int[i],char[SP]]}; PrintPoint: PROC[ctx: Context, pt: Complex.Vec] = {PrintReal[ctx, pt.x]; PrintReal[ctx, pt.y]}; MagnifyPoint: PUBLIC PROC [ctx: Context, p: Complex.Vec] RETURNS[Complex.Vec] = { --magnify and position vt: Complex.Vec; vt.x _ p.x*ctx.magnify+ctx.position.x; vt.y _ p.y*ctx.magnify+ctx.position.y; RETURN[vt] }; UnMagnifyPoint: PUBLIC PROC [ctx: Context, p: Complex.Vec] RETURNS[Complex.Vec] = { --undo magnify and position vt: Complex.Vec; vt.x _ (p.x-ctx.position.x)/ctx.magnify; vt.y _ (p.y-ctx.position.y)/ctx.magnify; RETURN[vt] }; }. ÆFitIOImpl.mesa Maureen Stone March 14, 1985 6:25:19 pm PST treat samples as vertices of a polygon or a broken line treat samples as vertices of a polygon or a broken line convert my trajectory to an imager.trajectory FeedbackRec: TYPE=RECORD [ color: Imager.Color _ black, sampleSize: REAL _ 1, jointSize: REAL _ 2, nodeLength: REAL _ 2, nodeLineWidth: REAL _ 0, lineWidth: REAL _ 0 --for DrawSamples and DrawContour ]; Imager.MaskRectangle[ctx.imager,pt.x-size/2,pt.y-size/2,size,size]; Imager.MaskRectangle[ctx.imager,pt.x,pt.y,size,size]; IF stream=NIL uses previous stream. Otherwise, closes previous stream (if any) and sets current output stream to stream. IF close=FALSE just disables logging. Ê Ì˜Jšœ™Jšœ+™+šÏk ˜ Jšœ ˜ Jšœœ‹˜—J˜J˜Jšœ œ<˜JJšœ œ˜#Jšœœ ˜Jšœœ ˜Jšœœ˜Jšœœœ˜Jšœœœ-˜=J˜—šœ œ˜Jšœ œ+˜=Jšœ œ˜—Jšœœ˜šÏn œœœ&˜>Jšœ˜šœœÏc˜)šœ˜J˜)Jšœ˜"—J˜J˜FJ˜DJ˜FJšœL˜LJšœD˜DJ˜—J˜—š ž œ œ%œœœœ˜hJšŸ7™7Jšœœœ˜ Jšœ;˜;Jš œœœœœœ ˜4J˜0šœœ˜ Jšœ,œ"˜RJ˜1Jšœ˜—Jšœœ˜š˜Jšœœ˜=Jšœ˜—Jšœœ˜,J˜—š ž œ œ%œœœœ˜hJšœ9˜9Jšœœœ˜ Jš œœœœœœ ˜4J˜0šœœ˜ Jšœ+œ&˜UJ˜0Jšœ˜—Jšœœ˜ š˜Jšœœœ˜EJšœ˜—Jšœœ˜,J˜—šž œ œ'˜=Jšœœœ˜ Jšœ0˜0Jšœ5˜5Jšœœ ˜!J˜—šž œœ-œ˜eJšŸ7™7Jšœœœ˜˜ Jšœœ$œ˜7Jšœ˜"J˜—J˜'Jšœœœœ˜9Jšœ˜ J˜—š ž œœ7œœœ˜JšŸ-™-Jšœœœ˜˜Jšœœ6œ˜JJšœ;˜;J˜—J˜$Jšœœœœ˜9J˜—šž œ œ%œœ˜QJ˜Jšœ,˜,J˜Jšœ˜ —Jšœœ:˜PJ˜J˜—šžœœœœ˜IJšœœ˜%Jšœœ˜š œœœ"œœ˜>Jšœ2˜2J˜Jšœ˜ —Jšœœ@˜VJ˜J˜—šžœœœœ˜AJšœ!˜!šœœ˜Jšœœ˜š œœœ"œœ˜>J˜Jšœ˜ —Jšœ˜Jšœ˜Jšœ˜—J˜—J˜šœœ˜J˜—š žœ œœœœ˜AJšœœl™yJšœ œœœ˜&Jšœ˜Jšœœ˜Jšœ˜—š žœœœœœœ˜=J™%Jšœœœ˜ Jšœœ˜J˜—Jš ž œœœœœœ˜RJš ž œœœœœ˜NJš ž œœœœœœ˜WJš žœœœœœœ˜OJšž œœO˜_J˜J˜šž œ œ œ˜QJšŸ˜J˜J˜&J˜&Jšœ˜ J˜—šžœ œ œ˜SJšŸ˜J˜J˜(J˜(Jšœ˜ J˜—J˜J˜—…—'Î5`