QT C++ graphics display WIDGET
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
Chris:
I was thinking about this the other day.
I wonder when you are finished if we could convince you two to build a QT C++ graphics display WIDGET.
If the widget uses qt properties to control it then it can be used in linuxcnc python based screens.
I would think a modern C++ based widget would have potentially more performance then a python based one.
Then your hard work could be accessed by more people.
We'd get the C++ performance but still retain the python low-bar customize-ability.
Chris:Grotius wrote: Hi Chris,
Using Qt properties is no problem.
What kind of Qt properties are on the wishlist?
With that info we can determine it's complexity.
Thanks for responding. I looked at the python widget and made this list for discussion.
Not all are strictly need for display but the current version does these things (plus a couple more that are not that important now) I think the (mostly) made up names are descriptive enough.
I don't wish to steal this thread so could make a new topic if you wish to discuss further.PROPERTIES
BackgroundColor
DROInlayBackgroundColor
SIGNALS
GcodeProperties
GcodeErrors
CurrentSelectedLine
LoadingProgress
SLOTS
setView
LoadProgram
HiglightGraphicsLine
setGraphicsView
Clear
zoom
pan
rotate
setAlphaMode
setShowDro
SetDROUnits
feedPlotColors
RapidPlotColors
Please Log in or Create an account to join the conversation.
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
A QT C++ graphics widget is certainly on the list and has a high priority at the moment. A universal widget
would be perfect.
In the c++ division we need it for UdoS his application and Hal-Core needs a display widget.
Then the linuxcnc-python division could also use it.
Chris, thanks for the wishlist.
Showing the dro's with background color is possible as a % transparant local widget overlay.
We can add extra qt-properties for this.
This will take some time to figur out. But i have seen examples online, discussing this solution.
I think UdoS and the python implementations are closest related. Hal-Core needs to be able to load
6 axis robots including configurable rotation matrixes, stepfiles, maybe optional dxf files.
CurrentSelectedLine of the wishlist is the hardest part i think. Not the line selecton an sich,
but giving the selected gcode line number back to lcnc. Info about this is welcome.
Please Log in or Create an account to join the conversation.
- Reinhard
- Offline
- Platinum Member
- Posts: 508
- Thank you received: 94
looks like you're talking about a successor of gremlin ...
> Showing the dro's with background color is possible as a % transparant local widget overlay.
If overlay with qt is possible, I'd like to offer my position widget.
I'm actually playing with mvc pattern in qt and have a dockable widget, which handles all position stuff
> CurrentSelectedLine of the wishlist is the hardest part i think. Not the line selecton an sich,
> but giving the selected gcode line number back to lcnc. Info about this is welcome.
When I extended your dxf-viewer, I implemented selection of elements - together with repainting of selection in different color.
In this picture, combobox selects the active plane which fills the listbox with the elements and selected item from listbox is selected in graphic view.
Usually selected element is an information, that comes from linuxcnc backend. When I developed the graphic view in java, I worked out that too. The problem is, that status from backend does not really contain the information needed to update display according to expectations - especially if exact path is not enabled.
Only CAM needs to determine selection from graphic view. But CAM does not need to send that info to linuxcnc backend.
I think, the really hard stuff is no widget requirement, but model related. Means: getting the model information from backend as well as getting up to date informations about backend progress. So this work could be splitted into model tasks and view tasks.
@grotius
if you're skilled in graphic processing, what about a "real" improvement of gremlin?
Painting lines for tool paths is pretty basic. What about a real 3D preview of the chip removal?
I saw this in an early version of deskproto - really amazing
Then I got to know, that this was not by intention, but by accident (slow performance).
Anyway - I think you know what I mean:
Create a workpiece and then remove the toolpath with real tool diameters and tooldepth ...
Attachments:
Please Log in or Create an account to join the conversation.
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
I was investegating the widget overlay.
The label with the white background is a child widget of the opencascade widget and is raised().
The same result we get with qtstackedlayout.
The black text can be a QLabel, QPlaintextedit, added in the source code of the opencascade widget.
So far as i can see, a nice methode to go on with.
Create a workpiece and then remove the toolpath with real tool diameters and tooldepth ...
Ok tomorrow when i have time, i can test the opencascade doing a solid live cut as Reinhard suggested.
BRepAlgoAPI_Cut Class
Attachments:
Please Log in or Create an account to join the conversation.
- cmorley
- Offline
- Moderator
- Posts: 7778
- Thank you received: 2075
Looks like it does a simple search through arrays holding the graphics commands.
For instance this is what the cooments said about what the array self.traverse holds:
# traverse list - [line number, [start position], [end position], [tlo x, tlo y, tlo z]]
def highlight(self, lineno, geometry):
glLineWidth(3)
c = self.colors['selected']
glColor3f(*c)
glBegin(GL_LINES)
coords =
for line in self.traverse:
if line[0] != lineno: continue
linuxcnc.line9(geometry, line[1], line[2])
coords.append(line[1][:3])
coords.append(line[2][:3])
for line in self.arcfeed:
if line[0] != lineno: continue
linuxcnc.line9(geometry, line[1], line[2])
coords.append(line[1][:3])
coords.append(line[2][:3])
for line in self.feed:
if line[0] != lineno: continue
linuxcnc.line9(geometry, line[1], line[2])
coords.append(line[1][:3])
coords.append(line[2][:3])
glEnd()
for line in self.dwells:
if line[0] != lineno: continue
self.draw_dwells([(line[0], c) + line[2:]], 2, 0)
coords.append(line[2:5])
glLineWidth(1)
if coords:
x = reduce(lambda x,y:x+y, [c[0] for c in coords]) / len(coords)
y = reduce(lambda x,y:x+y, [c[1] for c in coords]) / len(coords)
z = reduce(lambda x,y:x+y, [c[2] for c in coords]) / len(coords)
else:
x = (self.min_extents[0] + self.max_extents[0])/2
y = (self.min_extents[1] + self.max_extents[1])/2
z = (self.min_extents[2] + self.max_extents[2])/2
return x, y, z
In the python module, emcmodule.cc
is what processes the commands to make openGL commands for glcanon.
PositionLogger must track the current position while running a program?
The overlay looks great.
Stretch goals would be ability to add special cases like a configurable shaped chuck and stock outline (for lathes)
I've always been annoyed by linuxcnc's zoom feature - It would be nice to be able to zoom from cursor position rather then a fixed point.
Thanks for exploring this!
Chris
Please Log in or Create an account to join the conversation.
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
Thank you for info. I hope i can figur this out.
Hi Reinhard,
The live cut is done. But this really need a high performance. It's interesting to code.
user-images.githubusercontent.com/448801...513-4a6b2b7242cd.mp4
Please Log in or Create an account to join the conversation.
- Reinhard
- Offline
- Platinum Member
- Posts: 508
- Thank you received: 94
Do you have the sources of opencascade?
I tried to get one, but wasn't successful. I don't have any grafic skills, so would like to change that.
For the java part, I got the interpreter result attached to the line number. So each graphic element has a line number and I have a map, where I find the grafic element by the line number.
Linuxcnc has current line number in status - so tracking current element was easy that way.
Please Log in or Create an account to join the conversation.
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
I have put the code over here:
[edit] github.com/grotius-cnc/temp/releases (it contains 4 files at the bottom)
I tried to get one, but wasn't successful. I don't have any grafic skills, so would like to change that.
The sources are : github.com/grotius-cnc/Linux-Pro/release....0.0/opencascade.deb
This will install sources, compile sources etc. Will take a while.
In the draw_primitive class are most important draw functions present, but you did already know this.
Please Log in or Create an account to join the conversation.
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
I just opened the repository for the Qt graphics widget. Mr. Morley and UdoS has already write acces.
github.com/grotius-cnc/Qt_Graphics_Widget
In the mainwindow that is used for runtests, i already tested some Qproperties. These work nice !
Please Log in or Create an account to join the conversation.
- Grotius
- Topic Author
- Offline
- Platinum Member
- Posts: 2244
- Thank you received: 1984
I added a dro example to the widget, please look and comment :
user-images.githubusercontent.com/448801...373-b3bdf14df8e4.mp4
To discus, the dro properties can be for example :
- textheight
- transparancy
- color
- contains just one QString for entire dro result
- dro position x,y
- not highlighted by mouse visit
etc, etc.
I only need to know more about the dro wishlist, thanks.
Please Log in or Create an account to join the conversation.