This is the fork of MMTabBarView which is used to build Vienna, an open source RSS/Atom newsreader. During a period when MMTabBarView seemed to be neglected, Vienna developers felt compelled to make changes to it.
We currently try to limit widening of divergences with Michael Monscheuer's version, but at the time being, some noticeable changes remain:
- while the original version requires 10.10+, Vienna's version up to v/1.4.12 were able to run on OS X 10.9. Later versions are build on Xcode 15 and have macOS 10.13 as minimum development target.
- Vienna's version adds support of macOS Sierra style tabs (contributed by @yourhead)
- we implement MMTabBarView's
delegate
property as weak, in order to avoid retain cycles - animations differ
- we add a delegate method
-tabView:selectOnClosingTabViewItem:
for choice of next tab to be selected on closing a tab - we add a method
-closeTabViewItem:
for closing a tab view item, with due execution of all delegate methods - we add support of Swift Packet Manager (Cocoapod and Carthage remain supported)
Note that to limit risks of confusion with the original version, we use a v/x.x.x
scheme for version numbering.
Ex: our v/1.4.7
can be compared to Mimo's v1.4.1
A Mac OS X tab bar view that works on 10.10+ with Xcode 9.3 or higher.
MMTabBarView is a modernized and view based re-write of PSMTabBarControl,
which can be found here: https://github.com/dorianj/PSMTabBarControl
Though MMTabBarView's API is quite similar, it is no drop-in replacement for PSMTabBarControl.
The MMTabBarViewDelegate protocol is somewhat different.
But MMTabBarView will help you: The methods of the delegate protocol of PSMTabBarControl have been
included and set to deprecated. That means your compiler shows deprecation warnings (if switched on) for
all your old delegate method implementations. Transition will be a matter of minutes.
If you want to support this project, there are various ways in which you could do this:
- Send me a pull request.
- Review it on your site or blog.
- Make a donation via PayPal following the link below (credit cards etc. accepted too).
Donating via PayPal is as easy as clicking the donate button on this page: http://mimo42.github.com/MMTabBarView/
If you make any improvements, please submit them as pull requests.
To, build, simply open default.xcworkspace, choose MMTabBarView Demo scheme and run. The workspace contains two projects, the MMTabBarView framework and the Demo application.
Add the .framework bundle to your Xcode project, and add it to the Linked Frameworks and Libraries (under Target -> Summary). Next, under Target -> Build Phases, Add a new build phase that copies it to the Frameworks directory of your app. (Add Build Phase > Copy Files. Destination: Frameworks).
Do not forget to set LD_RUNPATH_SEARCH_PATHS
to @loader_path/../Frameworks
in your Xcode project.
Some components and lines originally were created by Positive Spin Media. The original is BSD licensed.
See: http://www.positivespinmedia.com/dev/PSMTabBarControl.html License
The re-write is also BSD licensed.
Since 2005 there have been lots of commits by various contributors.
Thanks to the guys recently improved PSMTabBarControl and inspired me to finally do the re-write!
Copyright © 2005, Positive Spin Media. All rights reserved.
Copyright © 2018, Michael Monscheuer. All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
* Neither the name of Positive Spin Media nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.