- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我像这样创建 NSView
的子类:
class MyView: NSView {
var field = NSTextField(frame: NSMakeRect(0, 0, 35, 22))
func drawRect(dirtyRect: NSRect) {
super.drawRect(dirtyRect)
field.stringValue = "Hello World"
self.addSubview(field)
}
}
...然后我可以根据需要创建此 View 的任意多个实例:
let view1 = MyView()
let view2 = MyView()
// ... more instances
...然后用它们做任何我想做的事:
view2.field.stringValue = "foo"
addSubview(view1)
addSubview(view2)
但是,实际上我正在尝试创建一个包含多个 NSTextField
的 View 。因此,弄清楚每个 NSTextField
的框架应该是什么是相当乏味的,更不用说如果我想编辑其中的任何一个,事情很快就会变得一团糟。这就是 Interface Builder 派上用场的地方。但是我从来没有遇到过使用 Interface Builder 创建类声明的方法。我已经多次创建 NSView
的子类,将“自定义 View ”拖到 nib 文件中,向 View 添加一些东西,从中的对象创建一些 IBOutlets
“自定义 View ”到我的子类,将“自定义 View ”的类更改为我的子类,一切正常。但这是不可重现的(至少据我所知)。它只是我的类的一个特定实例,由 IB 初始化,仅此而已 - 只有一个实例。但我想要的是一种重现这种观点的方法。我希望能够设计一个"template",可以这么说,在 IB 中,然后创建该模板的多个副本。必须有一个好的方法来做到这一点。也许使用 NSViewController
?有什么想法吗?
最佳答案
请参阅这篇文章,了解如何在 swift 中进行 nib 实例化。 Swift - Assign a NIB to self in class
我下面的示例已被弃用,但仍然可以正常工作。这是我为此使用了大约 50 次(在 objective-c 中)的设计模式。关键的“技巧”是在没有“init”的情况下调用“alloc”,就像这个例子:
NSViewController *nibFileOwner = [NSViewController alloc];
NSArray *theTopLevelObjects;
[theMbRemoteControlListNib instantiateNibWithOwner:nibFileOwner
topLevelObjects:&theTopLevelObjects];
处理布局问题仍然很痛苦,但至少 nib 可以解决一些问题。
在这个特定示例中,我正在创建一个比较工具来比较“服务器 A”配置和“服务器 B”配置。这只是此实现的框架。
// subclass as NSMatrix to support drawing reuse of resetButtonCell (BGHUDButtonCell)
@interface MbRemoteControlList : NSMatrix <NSTextFieldDelegate, NSMenuDelegate, EditingAlignmentProtocol>
{
NSArray *mTopLevelObjects;
IBOutlet NSViewController *toFilesOwner; // nib files owner
IBOutlet NSTextField *toFixNameText;
}
+ (MbRemoteControlList *)_privateCreate
{
////////////// BUILD MbRemoteControlList /////////////////////////////////
NSBundle *theClassBundle;
theClassBundle = [NSBundle mainBundle];
NSNib *theMbRemoteControlListNib = [[NSNib alloc] initWithNibNamed:@"MbRemoteControlList" bundle:theClassBundle];
// A simple NSViewController is the nib 'File's Owner' so we can access
// the MbRemoteControlList view in the nib hierarchy.
NSViewController *nibFileOwner = [NSViewController alloc];
NSArray *theTopLevelObjects;
[theMbRemoteControlListNib instantiateNibWithOwner:nibFileOwner
topLevelObjects:&theTopLevelObjects];
MbRemoteControlList *newObj = (MbRemoteControlList *)[nibFileOwner view];
if ( nibFileOwner != newObj->toFilesOwner )
{
DLogErr( @"MbRemoteControlList creation error");
return nil;
}
newObj.mTopLevelObjects = theTopLevelObjects;
[theMbRemoteControlListNib autorelease];
if ( newObj.mTopLevelObjects )
return newObj;
DLogErr( @"MbRemoteControlList creation error");
return nil;
}
+ (MbRemoteControlList *) create
{
setupLayout();
sLeftServer = [MbRemoteControlList _privateCreate];
if ( !sLeftServer ) return nil;
MbRemoteControlList *rightServer = [MbRemoteControlList _privateCreate];
if ( !rightServer ) return nil;
[sLeftServer setupWithRightServer: rightServer];
return sLeftServer;
}
此实现的相关布局技巧:
// sLeftServer is the owner of the active server list
static MbRemoteControlList *sLeftServer;
static BOOL sIsComparingNow = NO; // true if side-by-side comparing with another servers prefs
static BOOL sInitDone = NO;
#define kPrefsUseSmallFont @"kPrefsUseSmallFont"
static BOOL sSmallSize = NO;
static int sOrigBaseWidth = 701;
// action menu items
enum
{
kLargeFontSize = 1,
kSmallFontSize = 2
};
typedef struct LayoutStruct
{
NSControlSize controlSize;
int rowHeight;
int fontSize;
int resetColumnWidth;
int prefValueWidth;
int contentWidth;
int copyingControlsWidth;
int scrollViewWidth1;
int rightSideOriginX;
int toCommandsPopupOriginX;
int scrollViewWidth2;
} _LayoutStruct;
static LayoutStruct sLayout;
// layout constants
// preference name & value 250
// list view 250 + 20 = 270
// total window
// 6 + 270 + 60? + 282 + 18 + 6
// #define kResetColumnWidth 20 // (needs to match value in nib + 1)
// #define kPrefValueWidth 250 // (needs to match the nib)
// #define kContentWidth (kResetColumnWidth + kPrefValueWidth + 6)
// #define kCopyingControlsWidth 120
// #define kScrollViewWidth1 (kContentWidth + 18)
// #define kRightSideOriginX (kContentWidth + kCopyingControlsWidth)
// #define kScrollViewWidth2 (kRightSideOriginX + kContentWidth + 18)
//
// #define kDefaultRowHeight 20
static float sWidthFactor = 1.0;
#define textFieldStringWidth (int(100 * sWidthFactor))
#define textFieldFloatWidth (int(40 * sWidthFactor))
#define textField5DigitWidth (int(39 * sWidthFactor))
#define textField4DigitWidth (int(33 * sWidthFactor))
#define textField3DigitWidth (int(27 * sWidthFactor))
void setupLayout()
{
sSmallSize = [[[NSUserDefaults standardUserDefaults] objectForKey: kPrefsUseSmallFont] boolValue];
if ( sSmallSize == YES )
{
sWidthFactor = 1.0;
sLayout.controlSize = NSSmallControlSize;
sLayout.rowHeight = 20;
sLayout.fontSize = 9;
sLayout.resetColumnWidth = 20;
sLayout.prefValueWidth = 250;
sLayout.contentWidth = sLayout.resetColumnWidth + sLayout.prefValueWidth + 6;
sLayout.copyingControlsWidth = 120;
sLayout.scrollViewWidth1 = sLayout.contentWidth + 18;
sLayout.rightSideOriginX = sLayout.contentWidth + sLayout.copyingControlsWidth;
sLayout.scrollViewWidth2 = sLayout.rightSideOriginX + sLayout.contentWidth + 18;
sLayout.toCommandsPopupOriginX = sLayout.scrollViewWidth2 - 224;
}
else
{
sWidthFactor = 13.0 / 9.0;
sLayout.controlSize = NSRegularControlSize;
sLayout.rowHeight = 25; // same as Director kValueEditorViewHeight
sLayout.fontSize = [NSFont systemFontSizeForControlSize:NSRegularControlSize];
sLayout.resetColumnWidth = 20;
sLayout.prefValueWidth = 250 * sWidthFactor;
sLayout.contentWidth = sLayout.resetColumnWidth + sLayout.prefValueWidth + 6;
sLayout.copyingControlsWidth = 120 + 8;
sLayout.scrollViewWidth1 = sLayout.contentWidth + 18;
sLayout.rightSideOriginX = sLayout.contentWidth + sLayout.copyingControlsWidth;
sLayout.scrollViewWidth2 = sLayout.rightSideOriginX + sLayout.contentWidth + 18;
sLayout.toCommandsPopupOriginX = sLayout.rightSideOriginX + 8;
}
}
关于Swift:使用 Interface Builder 创建可重现的 NSView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34861898/
我正在开发一个应用程序,我成功地消除了除一个错误之外的所有错误: no suitable constructor found for builder 更改为“意图” https://file.io/O
我可以在 C++Builder 6 中成功编译以下代码片段,但我无法在 RAD Studio Seattle 中编译它: unsigned long x = 50; String s = In
我有一个项目(新开始),其中 C++ Builder 没有在任何断点处停止。我已确保我处于 Debug模式(未发布),链接器->完整调试信息 = True,C++ 编译器->调试配置,C++ 编译器-
我们想在正在开发的 C++ builder XE 应用程序中绘制大型控制流程图。 这些图表将以编程方式生成并以交互方式显示给用户(用户可以滚动大流程图、选择节点等)。节点必须能够显示自定义组件(如 T
我有以下问题 午餐时 FlashBuilder.exe (BURRITO):它崩溃并创建一个错误日志文件,例如: hs_err_pid7084.log 及以下 但是当我咀嚼 FlashBuilderC
我有一个大型 Flash Builder 项目,它是更大 (.net) 解决方案的一部分。对于整个项目,我通常有一个前进的开发分支,以及一个或多个错误修复分支。考虑到 Flash Builder 不想
乘数(自动布局中约束的属性)有什么作用? 最佳答案 约束中两个值之间的关系由以下公式确定: b = am + c 其中 a 和 b 是要关联的两个值,m 是乘数,c code> 是常量。 例如,如果
我们的开发团队使用 Borland C++ Builder 6 和 CodeGear C++ Builder 2007(以及 Visual Studio)。我听到很多评论说 Builder 2007
我想阐明我对构建器模式的使用,特别是构建器类型是如何创建的。在示例中,它只是假定构建器的类型并创建它。但是,我在“ChartBuilderFactory”类中创建了一个 CreateBuilder 方
首先,我对 Java 比较陌生,所以我问的可能是微不足道的,但我在这里或其他地方找不到答案。 为简单起见,假设我有以下类层次结构: class Shape { protected Shape(
我试图在另一个 AlertDialog 中打开一个 AlertDialog,但它不起作用,知道为什么它不起作用吗? String items[] = {"Details","Edit","Delete
我有一个包含 Form1 和 Form2 的程序。如何单击按钮从 form1 打开 form2? 最佳答案 更多信息 在你的 Project.cpp 中有这个:Application->CreateF
每当我使用 C++ Builder(XE4 版,但以前的版本也这样做)在 Release模式下构建 Win32 EXE 时,它总是创建一个导出目录并为我的项目中的每个单元导出一个 Initialize
我正在尝试在我的试用版 flashbuilder 上启用设计模式,但找不到任何选项, 我已经查看了 Windows 菜单,但没有启用设计模式, 和首选项,但首选项对话框中没有 Flex 来启用其设计模
我目前正在将一个大型 RAD Studio 2010 项目迁移到 XE4。作为其中的一部分,我正在重新创建许多项目文件。我想借此机会确保我们对预编译头使用最好的机制,因为似乎有几种方法可以做到这一点。
我观看了“Interface Builder 中的新增功能” session 视频并尝试复制显示的代码,但不幸的是,当我将 View 分配给具有 @IBDesignable 的自定义类时,出现 2 个
这个问题在这里已经有了答案: Why is NotificationCompat needed? (3 个答案) 关闭 5 年前。 我看到的几乎所有 Android 通知示例代码似乎都使用了 Not
我正在使用 fcm 从我的 Android 应用程序发送通知,并且我已经实现了它要求我提供的所有库。 val topic = "highScores" // See docum
我正在尝试在Flash Builder 4.6中进行项目范围内的查找和替换,但是对我而言,如何实现这一点并不明显。 我试过Edit-> Find/Replace然后全部替换,但它仅替换当前打开的文件中
帮助我在 XCode4 中取消 fubar 界面构建器。 我在 interface-builder 中创建了一个按钮,并在 View 的代码中为它定义了一个 IBAction 方法。它运行良好。然后我
我是一名优秀的程序员,十分优秀!