UITextView圆角、背景设置与居中

一、给UITextView绘制圆角,通过QuartzCore框架,操作CALayer可以给UITextView绘制圆角边框。

       textView.layer.cornerRadius = 6

       textView.layer.masksToBounds = YES

      通过cornerRadius可设置圆角弧度。

二、设置UITextView背景图片,在UITextView区域内。

      CGRect textViewFrame = CGRectMake(30.0,100.0,240.0,90.0);

      UITextView *textView = [[UITextView alloc] initWithFrame:textViewFrame];      

      UIImageView *imageView = [[UIImageView alloc] initWithFrame:[textView bounds]];

      imageView.image = [UIImage imageNamed:@"background.png"];

      [textView addSubview:imageView];

      [textView sendSubviewToBack:imageView];

三、设置居中

textField.textAlignment = UITextAlignmentLeft; //水平左对齐  

textField.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter;  //垂直居中  

运行效果如下:

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
你可以通过以下代码实现 UITextView 长按复制粘贴的功能: ```swift // 设置允许复制和粘贴 textView.isSelectable = true textView.allowsEditingTextAttributes = true textView.textContainerInset = UIEdgeInsets(top: 10, left: 0, bottom: 10, right: 0) // 添加长按手势识别器 let longPressGesture = UILongPressGestureRecognizer(target: self, action: #selector(longPress(_:))) textView.addGestureRecognizer(longPressGesture) // 长按手势识别器的响应函数 @objc func longPress(_ gestureRecognizer: UIGestureRecognizer) { // 获取长按的位置 let point = gestureRecognizer.location(in: textView) // 获取长按位置所在的字符索引 let characterIndex = textView.layoutManager.characterIndex(for: point, in: textView.textContainer, fractionOfDistanceBetweenInsertionPoints: nil) // 判断长按位置是否在文本范围内 if characterIndex < textView.textStorage.length { // 获取长按位置所在的单词 let range = textView.tokenizer.rangeEnclosingPosition(TextViewPosition(document: textView.textStorage), with: .word, inDirection: UITextDirection(rawValue: 1)) let word = textView.text(in: range!) // 弹出菜单 let menuController = UIMenuController.shared if !menuController.isMenuVisible { let copyMenuItem = UIMenuItem(title: "复制", action: #selector(copyText(_:))) let pasteMenuItem = UIMenuItem(title: "粘贴", action: #selector(pasteText(_:))) menuController.menuItems = [copyMenuItem, pasteMenuItem] menuController.setTargetRect(CGRect(x: point.x, y: point.y, width: 0, height: 0), in: textView) menuController.setMenuVisible(true, animated: true) } } } // 复制文本 @objc func copyText(_ sender: Any) { UIPasteboard.general.string = textView.text(in: textView.selectedTextRange!) } // 粘贴文本 @objc func pasteText(_ sender: Any) { if let pasteString = UIPasteboard.general.string { let selectedRange = textView.selectedRange let mutableAttributedString = NSMutableAttributedString(attributedString: textView.attributedText) mutableAttributedString.replaceCharacters(in: selectedRange, with: NSAttributedString(string: pasteString)) textView.attributedText = mutableAttributedString } } ``` 这里使用了 `UITextView` 的 `UITextInputTokenizer` 对象来获取长按位置所在的单词,并通过 `UIMenuController` 弹出菜单来实现复制和粘贴的功能。同时,需要在 `UITextView` 中设置 `isSelectable` 和 `allowsEditingTextAttributes` 属性为 `true`,并添加长按手势识别器来启用长按功能。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值