data:image/s3,"s3://crabby-images/f5068/f50688f853c6ec4ab58d7ac309d2bb40bcf8b6ce" alt="Totalfinder vs xtrafinder vs pathfinder 2018"
- #TOTALFINDER VS XTRAFINDER VS PATHFINDER 2018 CODE#
- #TOTALFINDER VS XTRAFINDER VS PATHFINDER 2018 FREE#
#TOTALFINDER VS XTRAFINDER VS PATHFINDER 2018 FREE#
var_38 appears to be a plain C array of CG window IDs (don't forget to free it) and var_2C appears to be the count. So in theory you should be able to use CGSCopyWindowGroup with magic "movementGroup" to detect parent-child relationships. I looked at the disassembly of AppKit framework and they are doing something like this. If CGSGetParentWindowList is not helpful. (I guess you don't want to implement this functionality by hand, I mean by taking screenshots of all windows in the parent-child hierarchy, consulting CG private APIs for their relative positions and compositing them by hand). I know that may be slower than your current method but this method should give you a composite screenshot of the window and all its child windows recursively. when taking a screenshot of a window which has some child windows you probably have to fall back to CGWindowListCreateImage.in user selection do not show windows which have some parent window ( CGSGetParentWindowList should give you answer wheter particular window is a child window or not).
#TOTALFINDER VS XTRAFINDER VS PATHFINDER 2018 CODE#
So from what I saw in your code you need to modify two things: and maybe some others, I think CGSGetParentWindowList looks like interesting method However, it is important to note that this is then an issue that the developer(s) of said application should consider a bug in their application.Įdit: There are also private APIs to detect if a window has a parent-window, which I assume would be the case for this particular TotalFinder window, by looking at the screenshot in the first post.Įxtern CGError CGSAddWindowToWindowMovementGroup(const CGSConnection cid, CGSWindow wid, CGSWindowMovementGroup group) Įxtern CGError CGSRemoveWindowFromWindowMovementGroup(const CGSConnection cid,ĬGSWindow wid, CGSWindowMovementGroup group)
data:image/s3,"s3://crabby-images/8968f/8968f06a279f9440d7a088110a05eec3c0616d54" alt="totalfinder vs xtrafinder vs pathfinder 2018 totalfinder vs xtrafinder vs pathfinder 2018"
Of course this has the inverse issue, where applications that report the wrong role by mistake is not classified correctly as a real window when it should be, and I have a system in place that will allow the user to specify these using various filters. In your case there might be other roles that should be considered valid windows, such as AXDialog etc.
data:image/s3,"s3://crabby-images/4a5ab/4a5ab0b6a760cb17c3a422a6ee592a773b21da25" alt="totalfinder vs xtrafinder vs pathfinder 2018 totalfinder vs xtrafinder vs pathfinder 2018"
Windows on macOS should report a kAXWindowRole of AXWindow, and kAXWindowSubrole
data:image/s3,"s3://crabby-images/f5068/f50688f853c6ec4ab58d7ac309d2bb40bcf8b6ce" alt="Totalfinder vs xtrafinder vs pathfinder 2018"