MacOS application without menu bar: Difference between revisions
AutoSpider (talk | contribs) (Convert ExpressionEngine links) |
No edit summary |
||
(3 intermediate revisions by 2 users not shown) | |||
Line 3: | Line 3: | ||
[[Category:HowTo]] | [[Category:HowTo]] | ||
Sometimes you want to create an application that runs in the background and should not have a menu bar or appear in the | Sometimes you want to create an application that runs in the background and should not have a menu bar or appear in the macOS Dock. There is no standard way in Qt itself to tell the application so (i.e. no setter on the QApplication object for example). | ||
Instead, one has to tell the | Instead, one has to tell the macOS application launcher via the application bundle configuration in Info.plist. The file is located in YourFancyApplication.app/Contents/Info.plist. It is added to the bundle by Qt automatically and contains your application's name and some other information which is filled in by qmake generated build steps. In order to remove the entire menu bar and dock functionality add to this file: | ||
<code> | <code> | ||
Line 33: | Line 33: | ||
<|]]— start of standard entries —> | <|]]— start of standard entries —> | ||
<key>CFBundleIconFile</key> | <key>CFBundleIconFile</key> | ||
<string> | <string>@ICON@</string> | ||
<key>CFBundlePackageType</key> | <key>CFBundlePackageType</key> | ||
<string>APPL</string> | <string>APPL</string> | ||
Line 39: | Line 39: | ||
<string>Created by Qt/QMake</string> | <string>Created by Qt/QMake</string> | ||
<key>CFBundleSignature</key> | <key>CFBundleSignature</key> | ||
<string> | <string>@TYPEINFO@</string> | ||
<key>CFBundleExecutable</key> | <key>CFBundleExecutable</key> | ||
<string> | <string>@EXECUTABLE@</string> | ||
<key>CFBundleIdentifier</key> | <key>CFBundleIdentifier</key> | ||
<string>com.yourcompany. | <string>com.yourcompany.@EXECUTABLE@</string> | ||
<key>NOTE</key> | <key>NOTE</key> | ||
<string>This file was generated by Qt/QMake.</string> | <string>This file was generated by Qt/QMake.</string> | ||
Line 53: | Line 53: | ||
</code> | </code> | ||
You can leave the | You can leave the @ICON@, @TYPEINFO@ and @EXECUTABLE@ placeholders as is, they are replaced with actual values by qmake/make once the Info.plist template is copied to your application bundle. |
Latest revision as of 21:59, 14 June 2016
This article may require cleanup to meet the Qt Wiki's quality standards. Reason: Auto-imported from ExpressionEngine. Please improve this article if you can. Remove the {{cleanup}} tag and add this page to Updated pages list after it's clean. |
Sometimes you want to create an application that runs in the background and should not have a menu bar or appear in the macOS Dock. There is no standard way in Qt itself to tell the application so (i.e. no setter on the QApplication object for example).
Instead, one has to tell the macOS application launcher via the application bundle configuration in Info.plist. The file is located in YourFancyApplication.app/Contents/Info.plist. It is added to the bundle by Qt automatically and contains your application's name and some other information which is filled in by qmake generated build steps. In order to remove the entire menu bar and dock functionality add to this file:
<key>LSUIElement</key>
<string>1</string>
See Apple's doc about LSUIElement for more info.
If you edit this file manually it may be overwritten by the build system (at latest if you call "make distclean"). Fortunatelly, qmake provides a configuration option to point to a custom Info.plist file, which you can pre-modify with the above snippet. Just add to your .pro file:
QMAKE_INFO_PLIST = /path/to/your/custom/Info.plist
See the docs about QMAKE_INFO_PLIST for some more details.
Caveat: If you modify the Info.plist template, it is not automatically replaced in the bundle as of this writing (2011-10-10, Qt version 4.7.2)! To trigger this, you will have to remove the application bundle directory.
To start easy, just grab the default file from /path/to/your/qt/installation/mkspecs/default/Info.plist.app and add the snippet above. This looks like this then:
<?xml version="1.0" encoding="UTF-8"?>
<[[Image:DOCTYPE plist SYSTEM "file://localhost/System/Library/DTDs/PropertyList.dtd">
<plist version="0.9">
<dict>
<|]]— start of standard entries —>
<key>CFBundleIconFile</key>
<string>@ICON@</string>
<key>CFBundlePackageType</key>
<string>APPL</string>
<key>CFBundleGetInfoString</key>
<string>Created by Qt/QMake</string>
<key>CFBundleSignature</key>
<string>@TYPEINFO@</string>
<key>CFBundleExecutable</key>
<string>@EXECUTABLE@</string>
<key>CFBundleIdentifier</key>
<string>com.yourcompany.@EXECUTABLE@</string>
<key>NOTE</key>
<string>This file was generated by Qt/QMake.</string>
<!— start of customized entries —>
<key>LSUIElement</key>
<string>1</string>
</dict>
</plist>
You can leave the @ICON@, @TYPEINFO@ and @EXECUTABLE@ placeholders as is, they are replaced with actual values by qmake/make once the Info.plist template is copied to your application bundle.