Review Request 127570: take advantage of "orientability" of arcs to solve a couple of longstanding problems for arcs by 3 points subject to change of concavity

Maurizio Paolini paolini at dmf.unicatt.it
Tue Apr 5 06:40:19 UTC 2016



> On April 4, 2016, 9:57 p.m., Aleix Pol Gonzalez wrote:
> > +1 from my side, although I don't know about the codebase, you seem to know what you're doing.
> > 
> > Would it be possible to set up some automated testing system?

I contributed a lot to kig in the past... however I come from the "C" world, not C++ (with its misteries :)
No idea how to set up a testing system; at least it requires some way to simulate the user interaction...
Concerning this proposal: actually there is a very little backward compatibility issue: the case of a user
that saved a kig construction that used e.g. the "firstEndPoint" of an arc by 3 points (constructed as a property of the
arc, not the point used to construct the arc), with the save file made *after* moving points to change the
concavity of the arc.   This is a risk that is even smaller than the one considered in my other review request:
https://git.reviewboard.kde.org/r/127364/ where I actually introduced the "orientability" of circles/arcs.
In that case, avoiding the backward compatibility issue was possible, but at the cost of a much less clean code.
All in all, considering that I estimate as "zero" the number of such saved kig files, I decided to follow the
cleaner path.


- Maurizio


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/127570/#review94258
-----------------------------------------------------------


On April 4, 2016, 3:49 p.m., Maurizio Paolini wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/127570/
> -----------------------------------------------------------
> 
> (Updated April 4, 2016, 3:49 p.m.)
> 
> 
> Review request for KDE Edu and David Narváez.
> 
> 
> Repository: kig
> 
> 
> Description
> -------
> 
> ArcBTPType can change concavity upon moving the defining points.  In such a situation the construction of the firstEndPoint and secondEndPoint properties get swapped and can lead to subsequent constructions that change abruptly.
> 
> Similarly the getPoint and getParam methods (that transform parameter t in [0,1] to a point in the arc and viceversa) is
> not defined smoothly upon change of concavity.
> A consequence of this is e.g. the sudden change of position of labels attached to an arc when the arc changes concavity.
> 
> The first problem is addressed by a test in the firstEndPoint and secondEndPoint methods.
> 
> The second problem is addressed by changing t in 1-t in both getParam and getPoint methods when mradius < 0.
> 
> 
> Diffs
> -----
> 
>   objects/other_imp.cc 7bc143e 
> 
> Diff: https://git.reviewboard.kde.org/r/127570/diff/
> 
> 
> Testing
> -------
> 
> The first problem can be made apparent with the following construction:
> 
> 1. Construct an arc by three points (say A, P, B)
> 2. Hide points A and B
> 3. Right-click on the arc and select Construct->First End Point
> 4. Move point P so that the the arc becomes a segment and then changes its concavity
> 
> Without the proposed patch observe the sudden jump of the newly created point
> 
> Similarly, the second problem becomes apparent with the further step:
> 
> 5. Right-click on the arc (in a position near an end-point) and select "Add Text Label->(any choice)"
> 6. Move point P as before
> 
> 
> File Attachments
> ----------------
> 
> kig construction showing the problem
>   https://git.reviewboard.kde.org/media/uploaded/files/2016/04/04/0d3f9dc5-06eb-4ec1-8b54-57ffc0c97b10__arc_param.kig
> snapshot of the kig file construction
>   https://git.reviewboard.kde.org/media/uploaded/files/2016/04/04/b8532477-262c-4d0a-9c19-a1b3ce0e98a3__arc_param.png
> 
> 
> Thanks,
> 
> Maurizio Paolini
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-edu/attachments/20160405/808073b9/attachment.html>


More information about the kde-edu mailing list