NSView
में यह तरीका देता है कि दृश्य स्वयं आंतरिक सामग्री आकार के रूप में क्या सोचता है।
NSTextField
अपने सेल की wraps
संपत्ति पर विचार किए बिना इसकी गणना करता है, इसलिए यह एक पंक्ति में रखे गए पाठ के आयामों की रिपोर्ट करेगा।
-(NSSize)intrinsicContentSize
{
if (![self.cell wraps]) {
return [super intrinsicContentSize];
}
NSRect frame = [self frame];
CGFloat width = frame.size.width;
// Make the frame very high, while keeping the width
frame.size.height = CGFLOAT_MAX;
// Calculate new height within the frame
// with practically infinite height.
CGFloat height = [self.cell cellSizeForBounds: frame].height;
return NSMakeSize(width, height);
}
// you need to invalidate the layout on text change, else it wouldn't grow by changing the text
- (void)textDidChange:(NSNotification *)notification
{
[super textDidChange:notification];
[self invalidateIntrinsicContentSize];
}
यह ठीक है कि मैं क्या देख रहा हूँ से मेल खाता है। बस स्पष्ट करने के लिए, सेल पर 'लपेटें' संपत्ति की यह अनदेखी शेर में एक बग प्रतीत होती है जिसे माउंटेन शेर में तय किया गया है। इसलिए, यदि आप शेर को लक्षित कर रहे हैं और ऊपर आप 2 ओएस में अलग-अलग परिणाम देखेंगे जब तक कि आप शेर को गति तक लाने के लिए बगफिक्स लागू नहीं करते। –
हां, यह शेर में एक बग है। मैं वास्तव में चाहता हूं कि ऐप्पल इन मुद्दों को ओएस एक्स 10.7 और 10.8 दोनों में ठीक करे। मेरे कार्यान्वयन में, मैं विशेष मामलों के लिए कुछ और जांच करता हूं (उदाहरण के लिए यदि यह शेर है || यदि भाषा अंग्रेजी नहीं है) और मैंने अपनी ऊंचाई को थोड़ा अलग सेट किया है। फिर भी, जो मोनोलो पोस्ट किया गया वह एक अच्छी शुरुआत है। – Arvin
आंतरिक सामग्री सामग्री: जब आप setStringValue द्वारा टेक्स्ट को बदलते हैं तो विधि को कॉल नहीं किया जाता है:। – ideawu