问题
I'm creating a comment section much like the one Facebook uses for it's messaging section in it's iOS app. I want the UITextView
to resize the height so the text I'm typing fits inside it rather than you having to scroll to see the text that overflows. Any ideas how I might go about doing this? I've looked into maybe using a CGRect
that is assigned to the size and height of the text view which then matches the content size:
CGRect textFrame = textView.frame;
textFrame.size.height = textView.contentSize.height;
textView.frame = textFrame;
I assume I need some sort of function that detects when the text reaches the bounds of the UITextView
and then resizes the height of the view? Has anyone struggled with this same concept?
回答1:
You can adjust frame in this delegate method, do not forget to set textView's delegate to self.
-(BOOL)textView:(UITextView *)_textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text {
[self adjustFrames];
return YES;
}
-(void) adjustFrames
{
CGRect textFrame = textView.frame;
textFrame.size.height = textView.contentSize.height;
textView.frame = textFrame;
}
this solution is for iOS6 and prior... for iOS7 refer to this
StackOverflow Answer
回答2:
This is my solution, using autolayout and textView.contentSize.height
. Tested on iOS8 Xcode6.3 beta4.
There's one catch about the setContentOffset
at the end. I put it to avoid "wrong contentOffset" artefact when line count changes. It adds an extra unwanted blank space below the last line and it doesn't look very nice unless you set it back right after changing the constraint. Took me hours to figure this out!
// set this up somewhere
let minTextViewHeight: CGFloat = 32
let maxTextViewHeight: CGFloat = 64
func textViewDidChange(textView: UITextView) {
var height = ceil(textView.contentSize.height) // ceil to avoid decimal
if (height < minTextViewHeight + 5) { // min cap, + 5 to avoid tiny height difference at min height
height = minTextViewHeight
}
if (height > maxTextViewHeight) { // max cap
height = maxTextViewHeight
}
if height != textViewHeight.constant { // set when height changed
textViewHeight.constant = height // change the value of NSLayoutConstraint
textView.setContentOffset(CGPointZero, animated: false) // scroll to top to avoid "wrong contentOffset" artefact when line count changes
}
}
回答3:
On the TableViewController that holds the UITextView, update the data from the tableViewDataSource that gets put in the cell and then simply call this:
tableView.beginUpdates()
tableView.endUpdates()
Unlike tableView.reloadData(), this does not call resignFirstResponder
回答4:
First set the minimum height constraints to your TextView:
textView.heightAnchor.constraint(greaterThanOrEqualTo: view.heightAnchor, multiplier: 0.20)
(Make sure you are setting greaterThanOrEqualTo Constraint so that if intrinsic content height is more than this height, it takes intrinsic content height )
OR simple constant
textView.heightAnchor.constraint(greaterThanOrEqualToConstant: someConstant)
While configuring your textView, set isScrollEnabled to false
textView.isScrollEnabled = false
Now when you type on the textView, its intrinsic content size height will increase and it will push views below it automatically.
回答5:
contentsize
will not work in ios 7.
Try this:
CGFloat textViewContentHeight = textView.contentSize.height;
textViewContentHeight = ceilf([textView sizeThatFits:textView.frame.size].height + 9);
来源:https://stackoverflow.com/questions/13493702/how-to-resize-uitextview-while-typing-inside-it