- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 swift 3.0 开发一个项目,我在 UIStoryBoard 中有三个 numberOFLines 设置为 6 的 UILabel。在标签下方,我放置了三个 UIButton,它们用作“查看更多”选项。有时我的代码工作正常,如果我截断的标签显示“查看更多”按钮,一旦单击它会显示全部内容,而有时即使 UILabel 内容被截断它仍然不显示“查看更多”按钮所以我'我无法看到全部内容。我在代码中缺少什么,帮助将不胜感激。
import UIKit
class MP3ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate {
@IBOutlet var descriptionSeeMoreBtn: UIButton!
@IBOutlet var howToUseSeeMoreBtn: UIButton!
@IBOutlet var cautionsSeeMreBtn: UIButton!
var seeMoreIsShowing = false
@IBOutlet var cautionsContentLbl: UILabel!
@IBOutlet var howToUseContentLbl: UILabel!
@IBOutlet var descriptionContentLbl: UILabel!
override func viewDidLoad() {
self.descriptionContentLbl.sizeToFit()
self.howToUseContentLbl.sizeToFit()
self.cautionsContentLbl.sizeToFit()
getItButton.layer.cornerRadius = 5
activityIndicator.startAnimating()
let mediaID = mediaDetails?["entity_key"] as! String
let url = URL(string: Config.MP3_LIST + "?mediaId=\(mediaID)")
let task = URLSession.shared.dataTask(with: url!, completionHandler: { (data, response, error) in
if(error != nil){
print(error!);
DispatchQueue.main.sync(execute: {
self.activityIndicator.stopAnimating()
})
}
else{
do{
if let urlContent = data {
let serverResponseData = try (JSONSerialization.jsonObject(with: urlContent, options: JSONSerialization.ReadingOptions.mutableContainers)) as! NSDictionary
if(serverResponseData["error"] == nil){
self.mediaDetails = serverResponseData
print("Media :",self.mediaDetails!)
self.mediaList = (self.mediaDetails?["trackList"]as? NSArray)!
DispatchQueue.main.sync(execute: {
self.descriptionContentLbl.text = self.mediaDetails?["description"] as? String ?? "description...."
self.howToUseContentLbl.text = self.mediaDetails?["howToUse"] as? String ?? "How to use......."
self.cautionsContentLbl.text = self.mediaDetails?["cautions"] as? String ?? "cautions...."
let track = ((self.mediaDetails?["trackList"] as! NSArray)[0]) as! NSDictionary
self.activityIndicator.stopAnimating()
})
}
}
}
catch {
print("Error In Json De-serialization")
}
DispatchQueue.main.sync(execute: {
self.activityIndicator.stopAnimating()
})
}
})
task.resume();
}
override func viewDidAppear(_ animated: Bool) {
loadTheInitialLabelText()
self.tableView.tableFooterView = UIView(frame: .zero)
}
@IBAction func descriptionSeeMoreButtonPressed(_ sender: Any) {
if (seeMoreIsShowing) {
self.descriptionContentLbl.numberOfLines = 6
self.descriptionSeeMoreBtn.setTitle("see more", for: .normal)
}else {
self.descriptionContentLbl.numberOfLines = 0
self.descriptionSeeMoreBtn.setTitle("show less", for: .normal)
}
seeMoreIsShowing = !seeMoreIsShowing
}
@IBAction func howToUSeSeeMoreButtonPressed(_ sender: Any) {
if (seeMoreIsShowing) {
self.howToUseContentLbl.numberOfLines = 6
self.howToUseSeeMoreBtn.setTitle("see more", for: .normal)
}else {
self.howToUseContentLbl.numberOfLines = 0
self.howToUseSeeMoreBtn.setTitle("show less", for: .normal)
}
seeMoreIsShowing = !seeMoreIsShowing
}
@IBAction func cautionsSeeMoreButtonPressed(_ sender: Any) {
if (seeMoreIsShowing) {
self.cautionsContentLbl.numberOfLines = 6
self.cautionsSeeMreBtn.setTitle("see more", for: .normal)
}else {
self.cautionsContentLbl.numberOfLines = 0
self.cautionsSeeMreBtn.setTitle("show less", for: .normal)
}
seeMoreIsShowing = !seeMoreIsShowing
}
func loadTheInitialLabelText() {
let DescriptionTextheight = self.descriptionContentLbl.text?.height(withConstrainedWidth: self.descriptionContentLbl.frame.width, font: self.descriptionContentLbl.font)
if self.descriptionContentLbl.intrinsicContentSize.height < DescriptionTextheight! {
self.descriptionSeeMoreBtn.isHidden = false
}else{
self.descriptionSeeMoreBtn.isHidden = true
}
let howToUseTextheight = self.howToUseContentLbl.text?.height(withConstrainedWidth: self.howToUseContentLbl.frame.width, font: self.howToUseContentLbl.font)
if self.howToUseContentLbl.intrinsicContentSize.height < howToUseTextheight! {
self.howToUseSeeMoreBtn.isHidden = false
}else{
self.howToUseSeeMoreBtn.isHidden = true
}
let cautionsTextheight = self.cautionsContentLbl.text?.height(withConstrainedWidth: self.cautionsContentLbl.frame.width, font: self.cautionsContentLbl.font)
if self.cautionsContentLbl.intrinsicContentSize.height < cautionsTextheight! {
self.cautionsSeeMreBtn.isHidden = false
}else{
self.cautionsSeeMreBtn.isHidden = true
}
}
}
extension String {
func height(withConstrainedWidth width: CGFloat, font: UIFont) -> CGFloat {
let constraintRect = CGSize(width: width, height: .greatestFiniteMagnitude)
let boundingBox = self.boundingRect(with: constraintRect, options: .usesLineFragmentOrigin, attributes: [NSFontAttributeName: font], context: nil)
return boundingBox.height
}
}
最佳答案
你在设置它们的文本值之前调整你的标签大小,在设置它们的值之后调整大小。但这并不能解决问题。
我相信可能发生的情况是您的网络服务返回时间太长。因此,当您的网络服务正在等待时,您的程序的其余部分将继续执行。
因此,您最终会比较空标签并获取它们的高度,然后获取这些标签的固有内容大小。固有大小是非文本填充标签的大小,它小于您的函数为该标签计算的任何高度。这最终会隐藏您的按钮。
之后,URLSession 会为您提供数据并设置标签的文本值,但高度计算已经发生。
您可以尝试的快速解决方法是在设置标签文本后,在 ViewDidLoad URLSession 处理程序中调用 LoadInitialText()。
关于ios - UILabel 上的 instrictContentSize 在不同的实例中返回不同的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43752397/
我有一个 UILabel,其不透明度已通过使用 [UIColor clearColor] 更改为空白我现在想将标签内文本的不透明度更改为尽可能完整的级别。我该怎么做? 最佳答案 使用以下代码更改UIL
我在同一个站点中阅读了如何插入和 UILabel(子类 UILabel 并覆盖所需的方法)。在将它添加到我的应用程序之前,我决定在一个独立的测试应用程序中对其进行测试。代码如下所示。 这是 MyUIL
NSString *longStr = @"AAAAAAAAAA\nBBBBB\nCCCCCCCCCCCCCCCCCC"; 如何使用 UILabel 截断某些标签宽度: AAA... BBB...
我想在 UILabel.text 上有一个纹理。 这样做我对 UILabel 进行了子类化。使用 -drawTextInRect 方法,我尝试仅获取用于使用 CGImageMaskCreate 函数创
我正在尝试使用 iOS 6.0 中新的自动布局 api 构建动态布局。我尝试构建的布局有 2 个按钮,它们之间有一个标签,如下图所示: 我想要的是以灰色显示的容器 View 根据标签中的文本量增加或减
我不知道这是否是我做错了什么,但每次 iOS 6 到 7、7 到 8 以及从 8 到 9 的重大更新时,一些 UILabel 似乎不够大,我看到“...”因为标签被截断了。我现在必须通过应用程序并重置
我偶然发现了一个我不确定如何解决的问题。 正如您在此处看到的名称应该所在的标签(我从用户输入中获取名称,这意味着它是动态的)。如果写得太长,它只会覆盖其他标签。 此外,在 Storyboard中,UI
我是初学者,所以对于任何似乎被忽视或简单的事情,我深表歉意。 基本上,我想要做的是让屏幕上的日期选择器更新 UILabel,然后获取更新 UILabel 的结果并将其推回到前一个屏幕上的另一个 UIL
我有一个 UILabel 的 NSMutableArray。我需要能够在用户触摸时选择此 NSMutableArray 中的特定 UILabel,并将此触摸 UILabel 的中心移动到用户将手指拖动
我知道对于类的元素 UIButton和 UIBarButtonItem他们自动假设window.tintColor作为主要颜色,如果我在应用程序中随时为窗口设置新的 tintColor,则会立即更改。
我是开发者世界的新人,自 2 月份以来一直断断续续地使用 swift 和 Xcode。我希望有人能帮助我。我正在尝试制作一个简单的小费计算器,但似乎无法将两个 uilabels 放在一起。这就是我到目
我有一个单元格原型(prototype),我正在尝试向其添加两个标签。我有两个紧挨着的标签,但标签的大小是动态的,所以我希望第二个标签能够根据第一个标签的大小移动。 基本上,我希望两个标签之间有一个固
这个问题看起来很平常..但是我昨天遇到了问题,我在 xib 中添加了一个标签并为其创建了导出,我想要在该标签内有多行,按钮,所以我决定添加新的子里面有标签... UILabel *label; lab
我正在尝试实现一个可以更改 uilabel 字体大小的功能,我可以缩放 uilabel 大小(即 uilabel.size),然后自动更改 uilabel 的字体大小,示例应用程序是 InstaTex
如果我设置bottomLabel.text = Chinese character,当我运行它时我看不到aboveLabel,如果我调试 View 层次我可以看到它。so有什么问题吗? UIL
我不太确定标题是否符合我的要求,但我有一个带有一堆句子的 label,我想将它们中的每一个分开到不同的 UILabel 这是我的代码 var s: [String] = [] for (i
当我更改 UILabel 的文本属性时,它只会在应用程序中部分更新。 我试过将它放在 viewDidLoad 函数和单独的专用函数中,但无济于事。如果我在更新后将 Label.text 打印到控制台,
我正在尝试使用自动布局对齐两个 UILabel,其中第一个标签没有设置宽度但使用固有内容大小,第二个应该与第一个宽度相同,将文本换行。 理想情况下,第二个标签应将数字行设置为 0 以使用动态类型,但我
我有几个标签,它们永远不应该相互接触。见下图(忽略黄色字母): 一共是4个标签,2个选手名字,2个分数。球员的名字将取代原来的球员标签文本。所以“玩家 1:”可以是任意宽度的任意文本。标签在 View
我正在开发一个应用程序,我需要能够点击并拖动 UILabels。第二个挑战是我需要屏幕上的其他 UILabel 相互移开(切勿重叠)。因此,当我拖动一个标签并遇到另一个标签时,它会将第二个标签撞开。也
我是一名优秀的程序员,十分优秀!