Fonction d'interfaçage
fr
CURV_f
function [x,y,typ]=CURV_f(job,arg1,arg2)
// Copyright INRIA
x=[];y=[];typ=[];
select job
case 'plot' then
standard_draw(arg1)
case 'getinputs' then
[x,y,typ]=standard_inputs(arg1)
case 'getoutputs' then
[x,y,typ]=standard_outputs(arg1)
case 'getorigin' then
[x,y]=standard_origin(arg1)
case 'set' then
x=arg1
model=arg1.model
graphics=arg1.graphics
rpar=model.rpar
ipar=model.ipar
n=ipar(1)
xx=rpar(1:n);yy=rpar(n+1:2*n)
gc=list(rpar(2*n+1:2*n+4),ipar(2:5))
while %t do
[ln,fun]=where();
if or(fun == "clickin") then // cas standard
old_win=xget('window')
win=maxi(winsid())+1
xset('window',win);xsetech([0 0 1 1])
[xx,yy,ok,gc]=edit_curv(xx,yy,'axy',[' ',' ',' '],gc)
xdel(win)
xset('window',old_win)
else
ok=%t
end // no need anymore to overload edit_curv in do_eval
if ~ok then break,end
n=size(xx,'*')
if or(xx(2:n)-xx(1:n-1)<0) then
message('You have not defined a function')
ok=%f
end
if ok then
model.sim='intplt'
model.firing=[] //compatibility
rect=gc(1)
model.rpar=[xx(:);yy(:);rect(:)]
axisdata=gc(2)
model.ipar=[size(xx,'*');axisdata(:)]
x.graphics=graphics;x.model=model
break
end
end
case 'define' then
xx=[0;1;2];yy=[-5;5;0]
rect=[0,-5,2,5];
axisdata=[2;10;2;10]
ipar=[size(xx,1);axisdata(:)]
rpar=[xx;yy;rect(:)]
model=scicos_model()
model.sim='intplt'
model.in=[]
model.out=1
model.rpar=[xx;yy;rect(:)]
model.ipar=[size(xx,1);axisdata(:)]
model.blocktype='c'
model.dep_ut=[%f %t]
gr_i=['rpar=arg1.model.rpar;n=model.ipar(1);';
'thick=xget(''thickness'');xset(''thickness'',2);';
'xx=rpar(1:n);yy=rpar(n+1:2*n);';
'rect=rpar(2*n+1:2*n+4);';
'mxx=rect(3)-rect(1);';
'mxy=rect(4)-rect(2);';
'xx=orig(1)+sz(1)*(1/10+(4/5)*((xx-rect(1))/mxx));';
'yy=orig(2)+sz(2)*(1/10+(4/5)*((yy-rect(2))/mxy));';
'xpoly(xx,yy,''lines'');';
'xset(''thickness'',thick);']
x=standard_define([2 2],model,[],gr_i)
end
endfunction