|  |  | | | Home » Developing U++ » UppHub » Scatter: FEATURE IDEAS (1 already done) Goto Forum:
	| 
		
			|  Scatter: FEATURE IDEAS (1 already done) [message #25670] | Sun, 07 March 2010 12:31  |  
			| 
				
				|  |  kohait00 Messages: 939
 Registered: July 2009
 Location: Germany
 | Experienced Contributor |  |  |  
	| hi andrej 
 i more and more get warmer with the Scatter, really like it and the interface. had developped own diagram control, but yours is far better
  i will try to provide some ideas though, to maybe enhance functionality of Scatter and if i can also the solutions. then you decide.. 
 1) attached value popup
 when clicking into diagram, a popup appears, and remains static, while moving clicked to other locations. better to have the popup travel with mouse showing values, isn't it? best, to have it selectable, which behaviour to have. attached a solution, maybe you like it..it does not have it swicthable though, but it works.
 
 2) zooming / moving
 when zooming out extremely (in tab8 i.e) the scatter hangs somewhere. the zoom is always realizes/painted respect to the SetXYMin Values. better would be to realize zoom centered to the current mous position, which is not that easy, i know, had my struggles
  . also logrithmic stuff is hard to handle as hell. maybe the problem is that the frature of drawing funcitons stands in the way.. 
 3) marks drawing
 it would be cool to have the drawing reticle marks selected dynamicly according to zoomfactor also, they are already accrding to move position, but zooming zooms also the reticle.
 i.e devisions -100 .. 50 .. 0 .. 50 .. 100 would step by step be changed to -75 .. -25 .. 25 .. 75 then -50 .. 25 .. 0 .. 25 .. 50
 may be i can provide you a testcase with my diagram in this sense, it adapts the graph marks when moving and zooming
 
 4) having graphs accessible via VectorMap, instead of Vector
 i saw that one can access the data directly, but the data is organized in Vector< Vector<XY> >, which is ok, but when users dynamicly will want to access and modify same things, while other graphs are removed, the index is changed, and one needs to keep trak of indices in a map. wo why not using a map directly. the performance hit is neglectable anyway. this would hide away the index problem.
 
 5) moving points of graphs
 one of the goals in my diagram was to have it a sort of controling control, where one can drag some points of graph around, while some not, so i.e realizing parametrize of a eq filter bank or the like.
 
 now these are some of the ideas i had in mind in my diagram. maybe you will find some of them usefull
  in case of help needed, ask.. 
	
	 Attachment: Scatter.rar (Size: 9.56KB, Downloaded 453 times)
 |  
	|  |  |  
	|  |  
	|  |  
	| 
		
			| Re: Scatter: FEATURE IDEAS (1 already done) [message #25911 is a reply to message #25902] | Fri, 19 March 2010 09:17   |  
			|  |  
	| I agree with you Andrei! 
 | andrei-catalin wrote on Thu, 18 March 2010 21:36 |  | Certainly the number of options for a chart can be much higher. There are many aspects that could be customized. For now, Scatter can be considered only a starting point or a basic package. A list of new features that you want and concrete ideas would be formed. But I think that should be developed a new charting package, better structured and which to use painter.
 
 Andrei
 
 | 
 
 |  
	|  |  |  
	| 
		
			| Re: Scatter: FEATURE IDEAS (1 already done) [message #26205 is a reply to message #25911] | Mon, 12 April 2010 18:57   |  
			| 
				
				|  |  koldo Messages: 3452
 Registered: August 2008
 | Senior Veteran |  |  |  
	| | tojocky wrote on Fri, 19 March 2010 09:17 |  | I agree with you Andrei!
 
 | andrei-catalin wrote on Thu, 18 March 2010 21:36 |  | Certainly the number of options for a chart can be much higher. There are many aspects that could be customized. For now, Scatter can be considered only a starting point or a basic package. A list of new features that you want and concrete ideas would be formed. But I think that should be developed a new charting package, better structured and which to use painter.
 
 Andrei
 
 | 
 
 
 | 
 
 Hello all
 
 I think Scatter works rather well for now with actual design. Of course there is a lot of space for improvements:
 
 - Some of kohait00 ideas
 - Add menus in Scatter class (zoom in/out, fit, ...)
 - Implement new features in layout designer
 - More graphs like 2D bars
 - Documentation
 - Perhaps to add a second name for Scatter class, like "Plot2D"
 
 However, if I would have 20 hours for it I would begin a new Plot3D package to get things like this:
 
 
  
 
 
	
	 Attachment: dib.PNG (Size: 49.01KB, Downloaded 1303 times)
 
 Best regards
 Iñaki
 |  
	|  |  |  
	|  |  
	|  |  
	|  |  
	|  |  
	| 
		
			| Re: capsulated Scatter Vectors [message #26561 is a reply to message #26559] | Tue, 11 May 2010 16:33   |  
			| 
				
				|  |  kohait00 Messages: 939
 Registered: July 2009
 Location: Germany
 | Experienced Contributor |  |  |  
	| hey koldo, thx for replying 
 forget about the Scatter.rar in Scatter.rar. it was a remamanet from last change which i forgot to delete when making the new archive.
 
 the topmost stuff is the current.
 
 i agree with changing API not beeing a good idea. but during time i really got to apriciate a simple API, where not too much is beeing hidden from user, actually thinking, that the data comes from user, and user decides what to do with it, beeing the scatter graph only menas of visualizing them at some time. the Vector Containers as members are pretty cool capsulation of data handling on their own. so why IMHO unnessesarely exporting add/remove data extra.
 
 the whole thing is driven by the idea of keeping controls simple. to use and understand, and concerning their visualisation, beeing still in control of all (Refresh() especially.
 
 this was just an idea anyway, which i wanted to provide for anyone in need..i will continue to merge some of my diagram stuff, which is not that performant, but has some of the "complicated" features described initially.
 
 @Plot3D, this thing is cool, but I have no time to do it
  one very fast ends up implementing own 3d engine, transform matrixes, viewpoints, world matrixes and all that (depending on rotation, translation and all of that). isnt there any lib already available for that (i mean computing 3d stuff in software, besides Mesa/DRI)? 
 another question: why the seperation between Parameters data points and Functional plots data points? couldnt they be managed all at in one? or is it a performance issue?
 
 
 |  
	|  |  |  
	| 
		
			| Re: capsulated Scatter Vectors [message #26562 is a reply to message #26561] | Tue, 11 May 2010 16:53   |  
			| 
				
				|  |  koldo Messages: 3452
 Registered: August 2008
 | Senior Veteran |  |  |  
	| | Quote: |  | @Plot3D, this thing is cool, but I have no time to do it
  one very fast ends up implementing own 3d engine, transform matrixes, viewpoints, world matrixes and all that (depending on rotation, translation and all of that). isnt there any lib already available for that (i mean computing 3d stuff in software, besides Mesa/DRI)? 
 | 
 
 Hello kohait00
 
 If I would do it I would implement it in OpenGL. U++ has an OpenGL demo that can be a very basic base.
 
 Best regards
 Iñaki
 [Updated on: Tue, 11 May 2010 17:31] Report message to a moderator |  
	|  |  |  
	| 
		
			| Re: capsulated Scatter Vectors [message #26563 is a reply to message #26559] | Tue, 11 May 2010 17:17   |  
			|  |  
	| | koldo wrote on Tue, 11 May 2010 16:12 |  | However there is no additional features for the user so I do not now if it is worthwhile.
 
 | 
 Hi,
 
 Just my two cents: I agree with kohait that having direct access to the data is IMHO a nice feature. Plots in PlotCtrl (which I still hope to finish during summer
  ) actually has Vector as its public base class. I believe that it is faster and simpler and it also allows in some cases to apply some general algorithms (e.g. Sort) on the data without pushing them back and forth. 
 Also I believe that the API doesn't have to change, just extend. If you keep the old functions and just add the direct access to data, there should be no problems with backward compatibility.
 
 Sorry if I didn't understand kohaits idea exactly, I just quickly scanned through the sources he posted...
 
 Best regards,
 Honza
 |  
	|  |  |  
	| 
		
			| Re: capsulated Scatter Vectors [message #26566 is a reply to message #26563] | Tue, 11 May 2010 22:16   |  
			| 
				
				|  |  kohait00 Messages: 939
 Registered: July 2009
 Location: Germany
 | Experienced Contributor |  |  |  
	| thanks guys for participating, its fun developing like that  
 here comes a version where i tried to remove the commented unnecessary stuff and have unified the usage of dthe Plot Data, merging the 2 cases of a given values plot and the drawing functions plot. it works just the same, and as benefit, the interface becomes more straightforward.
 
 API:
 i agree with keeping API compatible to old stuff. but the problem here is that the functions for adding data plots and function plots don't match syntactically.
 
 porting is actually an easy thing to do, if accompishing to name the public members of the class well, this woule encourage (enforce) the users of Scatter to quickly port their app.
 
 another way could be to hide the new implementatio in own namespace. Something like SlimScatter::Scatter, so a user later can decide about the porting point easily.. an to make the real Scatter a separate wrapper class, that keeps the old API but only  translates it to the new Scatter, which would keep out all the compatibility thing from the new Scatter
 
 something like
 
 
namespace SlimScatter
{
class Scatter
{
//new clean implementation
}
}
class Scatter : public SlimScatter::Scatter
{
//wrapping functions only
}
 @kolo: OpenGL ofcorse is best
  maybe i take a look in there... 
	
	 Attachment: Scatter2.rar (Size: 728.79KB, Downloaded 386 times)
 |  
	|  |  |  
	|  |  
	| 
		
			| Re: capsulated Scatter Vectors [message #26583 is a reply to message #26581] | Wed, 12 May 2010 23:07   |  
			| 
				
				|  |  kohait00 Messages: 939
 Registered: July 2009
 Location: Germany
 | Experienced Contributor |  |  |  
	| | Quote: |  | 
 the old code from user point of view has less lines and follows more U++ style.
 
 
 | 
 
 I totaly agree on that one. my changes have neither performance improvements nor beauty changes. the point its all about is, to define what is the core of the Scatter control. as of my point of view it is the data, not the API (which was to be read fine but was hiding away the data too much and IMHO bloatet the API a bit).
 
 andrejs goal was to have a Scatter control with a neat API to post stuff to and forget about it. my goal is to be able to access the data of the graphs in tried and true containers' manner (Vector..) and thus public and to see the Scatter just as a wrap over the data, which, upon triggering of Refresh()/Paint() draws a representation of it. so its basicly a question of design goals.
 
 the current solution could be improved in readability by changing the PData members' names to something more usefull, which i havent done so far (wanting to keep the visibility where the members came from and to make compare in svn easy not to change too much at once). also, the "more lines" stuff could be done better, by returning PData & instead of Scatter & AddSeries..
 i will provide a cleaned up version to sea what i mean.
 
 from code point of view, my current code leaves the control with almost only the code needed to draw the data. as api see the Vector<PData> API which is cool as well. another benefit is that functional plots are handled just the way normal plots are.. making code clearer again.
 
 i hope this came clear..it was not my goal to enhance the api but simplify it by leaving stuff accessible instead of hiding it behind api. (this is what i learned as well that sometimes its better not to hide)
 
 
 | Quote: |  | 
 So it would be great to let linking external data sets from:
 
 - C arrays
 - ArrayCtrl columns
 - GridCtrl columns
 
 
 | 
 
 this is a great idea.. could be done in some Additional AddSeries() functions..
 
 BTW: OpenGL, i am starting to like it.. the only thing is to create the vertices from data, set the viewpoint and have the stuff rotate depending on mouse position as seen on a surface of a bounding sphere.
 
 
 |  
	|  |  |  
	|  |  
	|  |  
	|  |  
	|  |  
	| 
		
			| Re: capsulated Scatter Vectors [message #26641 is a reply to message #26639] | Mon, 17 May 2010 21:31   |  
			| 
				
				|  |  kohait00 Messages: 939
 Registered: July 2009
 Location: Germany
 | Experienced Contributor |  |  |  
	| | Quote: |  | 
 Koldo version and Konstantin version will build up onto Catalin version.
 
 
 | 
 
 i'd prefer to build on someones code, ofcorse. deriving and extending a class is best. but in this case, my code change implies making data components public. so i cant derive from andrej's code. on the other hand, it'd be great not to have to duplicate code in the Scatter versions, i.e. the drawing routines, which i pretty like.
 
 nevermind, if it is possible and easy to do, we could split the code, crediting the sources to andrej ofcorse, and i could start to include some of the ideas described earlier.
  
 PS: MVC pattern is nice and great to do tings..but i remember a wise man (mirek
  saying: simplicity is a virtue on it's own. i think the building pieces for own ideas (Ctrl's, Container's, plug-ins) are simple and structured enough to take advantage of their API where possible..without the need to invent own API just to hide a memeber that has a great API on its own anyway. |  
	|  |  | 
 
 
 Current Time: Sun Oct 26 20:34:41 CET 2025 
 Total time taken to generate the page: 0.03885 seconds | 
 | 
 |