UIImageView加载网络图片,NSOperationQuene异步加载图片

本文介绍了一个iOS应用中使用UIWebView显示HTML内容的方法,并详细解释了如何处理页面内的图片加载,包括图片下载及展示过程。文章还涉及了UIWebView的配置细节及其与UIScrollView的交互设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. #import "newDetailViewController.h"  
  2. #import "Common.h"  
  3. #import "newObject.h"  
  4. #import "NetRequest.h"  
  5. #import <UIKit/UIKitDefines.h>  
  6.   
  7.   
  8. @interface newDetailViewController ()<UIWebViewDelegate>  
  9. {  
  10.     UILabel *GWDetailTitleText;  
  11.     UILabel *GWDetailTitleText1;  
  12.     UITextView *GWDetailContentText;  
  13.       
  14.     UIImageView *imageview;  
  15.     NSURL *url;  
  16.       
  17.     UIView *opaqueview;  
  18.     UIActivityIndicatorView *activityIndicator;  
  19.       
  20. }  
  21. @end  
  22.   
  23. @implementation newDetailViewController  
  24.   
  25. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil  
  26. {  
  27.     self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];  
  28.     if (self) {  
  29.         if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7) {  
  30.             self.view.bounds = CGRectMake(0, -20self.view.frame.size.widthself.view.frame.size.height );  
  31.         }  
  32.     }  
  33.     return self;  
  34. }  
  35.   
  36. - (void)viewDidLoad  
  37. {  
  38.       
  39.      [UIApplication sharedApplication].statusBarHidden = YES;  
  40.     [super viewDidLoad];  
  41.     //[self initView];  
  42. }  
  43.   
  44. -(void)initView  
  45. {  
  46.       
  47.     UIButton *loginButton = [[UIButton alloc]initWithFrame:CGRectMake(SCREEN_WIDTH - 4004030)];  
  48.     [loginButton setTitle:@"返回" forState:UIControlStateNormal];  
  49.     loginButton.titleLabel.textColor =[UIColor blackColor];  
  50.     [loginButton addTarget:self action:@selector(backtofather) forControlEvents:UIControlEventTouchUpInside];  
  51.     [self.view addSubview:loginButton];  
  52.       
  53.     GWDetailTitleText = [[UILabel alloc]initWithFrame:CGRectMake(1030, SCREEN_WIDTH - 2040)];  
  54.     GWDetailTitleText.textAlignment = NSTextAlignmentCenter;  
  55.     GWDetailTitleText.numberOfLines = 0;  
  56.     GWDetailTitleText.lineBreakMode = UILineBreakModeCharacterWrap;  
  57.     [self.view addSubview:GWDetailTitleText];  
  58.       
  59.       
  60.       
  61.     GWDetailTitleText1 = [[UILabel alloc]initWithFrame:CGRectMake(1070, SCREEN_WIDTH - 2020)];  
  62.     GWDetailTitleText1.textAlignment = NSTextAlignmentLeft;  
  63.     [self.view addSubview:GWDetailTitleText1];  
  64.   
  65.       
  66.       
  67.     web = [[UIWebView alloc]initWithFrame:CGRectMake(10100, SCREEN_WIDTH - 20self.view.bounds.origin.y + self.view.bounds.size.height - 110)];  
  68.     web.scalesPageToFit = YES;  
  69.     web.delegate = self;  
  70.     [[web layer] setCornerRadius:10];  
  71.     [web setClipsToBounds:YES];  
  72.     web.scalesPageToFit = NO;  
  73.     for (id subview in web.subviews)  
  74.     {  
  75.         if ([[subview class] isSubclassOfClass: [UIScrollView class]])  
  76.         {  
  77.             ((UIScrollView *)subview).bounces = NO;  
  78.         }  
  79.     }  
  80.     web.backgroundColor = [UIColor whiteColor];  
  81.     [self.view addSubview:web];  
  82.   
  83.       
  84.       
  85.       
  86. //    GWDetailContentText = [[UITextView alloc]initWithFrame:CGRectMake(10, 100, SCREEN_WIDTH - 20, self.view.bounds.origin.y + self.view.bounds.size.height - 110)];  
  87. //    GWDetailContentText.layer.borderWidth = 1;  
  88. //    GWDetailContentText.editable = NO;  
  89. //    [self.view addSubview:GWDetailContentText];  
  90.   
  91.   
  92. }  
  93.   
  94.   
  95. -(void)setchoicedDate:(newObject *)myarray  
  96. {  
  97.     [self initView];  
  98.      MyLog(@"%@  ", myarray );  
  99.     //MyLog(@"%@", myarray[0]);//[@"rel_title"]  
  100.     GWDetailTitleText.text = myarray.rel_title;  
  101.       
  102.     NSString *date =[[NSString alloc]initWithString:myarray.rel_date];  
  103.     date = [date substringToIndex:10];  
  104.     NSString *mystring = [NSString stringWithFormat:@"发布人:%@ 日期:%@",myarray.rel_user,date];  
  105.     GWDetailTitleText1.text = mystring;  
  106.     MyLog(@"%@",myarray.rel_picpath);  
  107.     if (![myarray.rel_picpath isEqualToString:@"null"]) {  
  108.         url = [NSURL URLWithString:[NSString stringWithFormat:@"%@%@",@"http://www.xf0573.com",myarray.rel_picpath]];  
  109.         imageview = [[UIImageView alloc]initWithFrame:CGRectMake(800160120)];  
  110.         imageview.layer.masksToBounds = YES;  
  111.         imageview.layer.cornerRadius = 5.0f;  
  112.         [imageview setBackgroundColor:[UIColor grayColor]];  
  113.         imageview.image = [UIImage imageNamed:@"moren.png"];  
  114.         [web addSubview:imageview];  
  115.           
  116.         opaqueview = [[ UIView   alloc initWithFrame: CGRectMake(00,  160120)];  
  117.         activityIndicator  = [[UIActivityIndicatorView   alloc initWithFrame: CGRectMake( 00,  160120)];  
  118.         [ opaqueview setBackgroundColor:[UIColor blackColor]];  
  119.         [ opaqueview setAlpha:0.6 ];  
  120.         [ imageview addSubview: opaqueview];  
  121.         [ opaqueview addSubview: activityIndicator];  
  122.         [ activityIndicator startAnimating ];  
  123.         opaqueview.hidden  = NO ;  
  124.           
  125.         web1 = [[UIWebView alloc]initWithFrame:CGRectMake(10120, SCREEN_WIDTH - 20self.view.bounds.origin.y + self.view.bounds.size.height - web.frame.origin.y - 130)];  
  126.         web1.scalesPageToFit = YES;  
  127.         web1.delegate = self;  
  128.         [[web1 layer] setCornerRadius:10];  
  129.         [web1 setClipsToBounds:YES];  
  130.         web1.scalesPageToFit = NO;  
  131.         for (id subview in web1.subviews)  
  132.         {  
  133.             if ([[subview class] isSubclassOfClass: [UIScrollView class]])  
  134.             {  
  135.                 ((UIScrollView *)subview).bounces = NO;  
  136.             }  
  137.         }  
  138.         web1.backgroundColor = [UIColor whiteColor];  
  139.         [web1 loadHTMLString:myarray.rel_content baseURL:nil];  
  140.         [web addSubview:web1];  
  141.           
  142.           
  143.         NSOperationQueue *operationQueue = [[NSOperationQueue alloc] init];  
  144.         NSInvocationOperation *op = [[NSInvocationOperation alloc] initWithTarget:self selector:@selector(downloadImage) object:nil];  
  145.         [operationQueue addOperation:op];  
  146.           
  147.           
  148.           
  149.         //[web loadRequest:req];  
  150.     }else if ([myarray.rel_picpath isEqualToString:@"null"])  
  151.     {  
  152.       
  153.     [web loadHTMLString:myarray.rel_content baseURL:nil];  
  154.     //GWDetailContentText.text = myarray.rel_content;  
  155.     }  
  156.   
  157. }  
  158. - (void)downloadImage  
  159. {  
  160.       
  161.     UIImage *image = [UIImage imageWithData:[NSData dataWithContentsOfURL:url]];  
  162.     imageview.image = image;  
  163.       
  164.     [activityIndicator stopAnimating];  
  165.     opaqueview.hidden  = YES ;  
  166. }  
  167.   
  168. -(void)backtofather  
  169. {  
  170.     [self dismissModalViewControllerAnimated:YES];  
  171. }  
  172. @end  
内容概要:本文深入探讨了Kotlin语言在函数式编程和跨平台开发方面的特性和优势,结合详细的代码案例,展示了Kotlin的核心技巧和应用场景。文章首先介绍了高阶函数和Lambda表达式的使用,解释了它们如何简化集合操作和回调函数处理。接着,详细讲解了Kotlin Multiplatform(KMP)的实现方式,包括共享模块的创建和平台特定模块的配置,展示了如何通过共享业务逻辑代码提高开发效率。最后,文章总结了Kotlin在Android开发、跨平台移动开发、后端开发和Web开发中的应用场景,并展望了其未来发展趋势,指出Kotlin将继续在函数式编程和跨平台开发领域不断完善和发展。; 适合人群:对函数式编程和跨平台开发感兴趣的开发者,尤其是有一定编程基础的Kotlin初学者和中级开发者。; 使用场景及目标:①理解Kotlin中高阶函数和Lambda表达式的使用方法及其在实际开发中的应用场景;②掌握Kotlin Multiplatform的实现方式,能够在多个平台上共享业务逻辑代码,提高开发效率;③了解Kotlin在不同开发领域的应用场景,为选择合适的技术栈提供参考。; 其他说明:本文不仅提供了理论知识,还结合了大量代码案例,帮助读者更好地理解和实践Kotlin的函数式编程特性和跨平台开发能力。建议读者在学习过程中动手实践代码案例,以加深理解和掌握。
内容概要:本文深入探讨了利用历史速度命令(HVC)增强仿射编队机动控制性能的方法。论文提出了HVC在仿射编队控制中的潜在价值,通过全面评估HVC对系统的影响,提出了易于测试的稳定性条件,并给出了延迟参数与跟踪误差关系的显式不等式。研究为两轮差动机器人(TWDRs)群提供了系统的协调编队机动控制方案,并通过9台TWDRs的仿真和实验验证了稳定性和综合性能改进。此外,文中还提供了详细的Python代码实现,涵盖仿射编队控制类、HVC增强、稳定性条件检查以及仿真实验。代码不仅实现了论文的核心思想,还扩展了邻居历史信息利用、动态拓扑优化和自适应控制等性能提升策略,更全面地反映了群体智能协作和性能优化思想。 适用人群:具备一定编程基础,对群体智能、机器人编队控制、时滞系统稳定性分析感兴趣的科研人员和工程师。 使用场景及目标:①理解HVC在仿射编队控制中的应用及其对系统性能的提升;②掌握仿射编队控制的具体实现方法,包括控制器设计、稳定性分析和仿真实验;③学习如何通过引入历史信息(如HVC)来优化群体智能系统的性能;④探索中性型时滞系统的稳定性条件及其在实际系统中的应用。 其他说明:此资源不仅提供了理论分析,还包括完整的Python代码实现,帮助读者从理论到实践全面掌握仿射编队控制技术。代码结构清晰,涵盖了从初始化配置、控制律设计到性能评估的各个环节,并提供了丰富的可视化工具,便于理解和分析系统性能。通过阅读和实践,读者可以深入了解HVC增强仿射编队控制的工作原理及其实际应用效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值