草庐IT

btn-block

全部标签

ios - iOS 9.1 启动屏幕上的黑色方 block

我刚刚在我的iPhone6s上升级到iOS9.1后注意到启动屏幕中间有一个黑色方block,所以它盖住了Logo。我使用LaunchScreen.xib文件。这一切都适用于以前的iOS版本和模拟器。有没有人有过这种经历并且知道如何解决?或者是需要报告的操作系统错误?这是我的启动屏幕的屏幕截图。编辑:我很确定黑色方block应该是图像。 最佳答案 这在某种程度上与损坏的.png图像有关。我很惊讶,因为它在其他任何地方都运作良好。更换图片,问题已解决。 关于ios-iOS9.1启动屏幕上的黑

ios - block 不捕获 self

我想尝试理解block捕获逻辑,现在我对此有疑问。我有MeRequest和NSNumber属性。@property(nonatomic)MeRequest*request;@property(nonatomic)NSNumber*number;然后,在viewDidLoad中调用请求方法self.request=[[MeRequestalloc]init];[self.requestmeInfoSuccessBlock:^(NSDictionary*response){}failureBlock:^(Error*error){self.number=@5;}];-(void)meInf

ios - MKTileOverlay:如何重新加载特定的图 block 或区域

我正在开发一个基于map的应用程序。我使用了MKTileOverlay来显示一些动态内容。当新信息到达时,有时某些图block需要重新加载。我尝试在主线程中调用overlayRenderer.setNeedsDisplayInMapRect(mapRect)但显然在我的情况下它不会触发map重绘。到目前为止,唯一可行的方法是overlayRenderer.reloadData()。但是,这将导致重新加载整个内容(而不是仅特定区域)并导致View闪烁,所以这对我来说不是一个选项。任何人都可以对此提出任何建议吗?谢谢和干杯。 最佳答案

ios - 尽管 NSAttributedString 不同意,为什么第二个文本 block 的行高比第一个高得多?

我得到一个包含两部分文本的NSAttributedString,第一部分只是纯文本,如下所示,之后是示例代码块,也如下所示(添加了分隔线以更轻松地显示)。如您所见,代码块的行数明显高于正常的文本正文:但是,没有多余的换行符或任何类似的东西。这是它的attributedString.string值:funcsampleFunction()->Bool{if4+4==8{returntrue}returnfalse}两者都在同一个NSAttributedString中,当我打印NSAttributedString时,我没有发现任何可以解释这一点的差异:Loremipsumdolorsita

objective-c - 构造带 block 参数的 NSInvocation

我正在尝试将Block作为参数发送给NSInvocation调用的方法(对于上下文,它由NSInvocationOperation触发)。调用应该保留参数,它似乎适用于“常规”对象参数,但Block的retainCount保持在1。我可以在方法调用中使用它之后释放它,但如果在调用操作之前队列被解散,理论上可能会泄漏它。部分代码:NSInvocationOperation*load=[[NSInvocationOperationalloc]initWithInvocation:loadInvoc];NSAssert([loadInvocargumentsRetained],@"Argum

ios - 带有 UI 回调的循环 block

我有一个耗时的过程,并且有一个进度指示器向用户显示事情已经进行了多长时间。因为我必须在主线程上执行消费操作,所以我无法选择在更新之间简单地在主队列上分派(dispatch)更新。我必须暂时切换到后台线程,以便在切换回并继续之前让UI更新。我有的就是这个,但是感觉很不正统。有没有更好的方法来执行我所缺少的“带有UI回调的循环block”?我也不完全确定这是否最终会释放block,但那是另一回事了。__blockNSUIntegeri=0;__blockdispatch_block_tobtainBlock;obtainBlock=[^{[selfobtainAssetAtIndex:i]

objective-c - 是否写入文件 :atomically: blocks asynchronous reading?

在使用我的应用程序时,有几次我在后台处理一些大数据。(在用户需要时准备好。某种索引。)当这个后台进程完成时,它需要将数据保存在缓存文件中,但由于这真的很大,所以需要几秒钟。但同时用户可能会打开一些显示从磁盘加载的图像和文本的对话框。如果在保存后台进程数据的同时发生这种情况,则用户界面需要等待保存过程完成。(这是不希望的,因为用户必须等待3-4秒,直到从磁盘加载图像和文本!)所以我正在寻找一种方法来限制写入磁盘。我想将数据分成block,并在保存不同block之间插入一个短暂的延迟。在此延迟中,用户界面将能够加载所需的文本和图像,因此用户不会意识到延迟。目前我正在使用[[arraycom

ios - Objective-C 中的一个奇怪的 block 问题

我有一个AuthService类,它有一个方法来执行异步连接以登录。此类实现了NSURLConnectionDataDelegate协议(protocol),因此当服务器响应时,它会调用先前由ViewController设置的完成处理程序来更新UI。这是完成处理程序的定义@propertyvoid(^completionHandler)(LoginResult*result);这是类接收服务器响应的时候-(void)connection:(NSURLConnection*)connectiondidReceiveData:(NSData*)data{NSString*response=

ios - 哪个更适合做异步?委托(delegate)还是 block ?

我有一个模型Model,它通过JSONAPI加载一些东西,然后我以某种方式在UI中显示它。假设一次只有一个current实例(根据时间从服务器获取),所以我有一个看起来像这样的方法调用[Modelcurrent]。问题是我需要在加载数据时做一些事情,这导致我有两种可能的解决方案:Delegation-类似于[ModelcurrentWithDelegate:self],我将在self上实现一个具有回调的协议(protocol)block-[ModelcurrentWithSuccess:^(idresponse){...}error:^(NSError*error){...}]因为我是

ios - 我真的必须创建两个版本的变量才能使用 objective-c block 吗?

有很多关于block和保留周期的问题......他们让我整理了以下代码:-(void)promptNewName{DTAlertView*prompt=[[DTAlertViewalloc]initWithTitle:@"Name"message:@"foobar"];prompt.alertViewStyle=UIAlertViewStylePlainTextInput;[promptaddCancelButtonWithTitle:NSLocalizedString(@"Cancel",nil)block:^{}];__weakDTAlertView*weakPrompt=prom