Yosemite 的 NSTabView 风格类似于 iTunes
NSTabView styled like iTunes for Yosemite
我正在尝试构建一个样式与 iTunes 中 NSPanel/NSWindow 相同的 NSTabView。这在您编辑曲目时弹出。
当我添加 NSTabview 时,它显示有一个带颜色和边框的矩形
我已尽我所能来删除此矩形,或将其设置为透明。有没有人找到解决方案?任何正确方向的指示都会非常有帮助。
您可以创建一个无表格的 NSTabView,然后您可以将 NSSegmentedControl 添加到 select 活动选项卡。
这里有一个编程解决方案供任何感兴趣的人使用:
- (void)createViews {
// tabview
self.tabView = [NSTabView new];
self.tabView.tabViewType = NSNoTabsNoBorder;
self.tabView.controlSize = NSRegularControlSize;
// tabview items
self.detailsTabItemView = [BPBaseView new];
NSTabViewItem *detailItem = [NSTabViewItem new];
detailItem.view = self.detailsTabItemView;
self.artworkTabItemView = [BPBaseView new];
self.artworkTabItemView.backgroundColor = [NSColor colorWithHex:BPCharcoalLight];
NSTabViewItem *artworkItem = [NSTabViewItem new];
artworkItem.view = self.artworkTabItemView;
[self.tabView addTabViewItem:detailItem];
[self.tabView addTabViewItem:artworkItem];
// segment control
self.segmentControl = [NSSegmentedControl new];
self.segmentControl.segmentCount = 2;
[self.segmentControl setLabel:@"Details" forSegment:0];
[self.segmentControl setLabel:@"Artwork" forSegment:1];
self.segmentControl.action = @selector(segmentControlClicked:);
self.segmentControl.selectedSegment = 0;
[self segmentControlClicked:self.segmentControl]; // force first view to show
// add views
[self.bottomContainerView addSubview:self.segmentControl];
[self.bottomContainerView addSubview:self.tabView];
}
- (void)segmentControlClicked:(id)segmentControl{
NSInteger index = [segmentControl selectedSegment];
[self.tabView selectTabViewItemAtIndex:index];
}
我正在尝试构建一个样式与 iTunes 中 NSPanel/NSWindow 相同的 NSTabView。这在您编辑曲目时弹出。
当我添加 NSTabview 时,它显示有一个带颜色和边框的矩形
我已尽我所能来删除此矩形,或将其设置为透明。有没有人找到解决方案?任何正确方向的指示都会非常有帮助。
您可以创建一个无表格的 NSTabView,然后您可以将 NSSegmentedControl 添加到 select 活动选项卡。
这里有一个编程解决方案供任何感兴趣的人使用:
- (void)createViews {
// tabview
self.tabView = [NSTabView new];
self.tabView.tabViewType = NSNoTabsNoBorder;
self.tabView.controlSize = NSRegularControlSize;
// tabview items
self.detailsTabItemView = [BPBaseView new];
NSTabViewItem *detailItem = [NSTabViewItem new];
detailItem.view = self.detailsTabItemView;
self.artworkTabItemView = [BPBaseView new];
self.artworkTabItemView.backgroundColor = [NSColor colorWithHex:BPCharcoalLight];
NSTabViewItem *artworkItem = [NSTabViewItem new];
artworkItem.view = self.artworkTabItemView;
[self.tabView addTabViewItem:detailItem];
[self.tabView addTabViewItem:artworkItem];
// segment control
self.segmentControl = [NSSegmentedControl new];
self.segmentControl.segmentCount = 2;
[self.segmentControl setLabel:@"Details" forSegment:0];
[self.segmentControl setLabel:@"Artwork" forSegment:1];
self.segmentControl.action = @selector(segmentControlClicked:);
self.segmentControl.selectedSegment = 0;
[self segmentControlClicked:self.segmentControl]; // force first view to show
// add views
[self.bottomContainerView addSubview:self.segmentControl];
[self.bottomContainerView addSubview:self.tabView];
}
- (void)segmentControlClicked:(id)segmentControl{
NSInteger index = [segmentControl selectedSegment];
[self.tabView selectTabViewItemAtIndex:index];
}