在UIView上添加一个导航栏

Java代码   收藏代码
  1. - (id)initWithFrame:(CGRect)frame {  
  2.       
  3.     self = [super initWithFrame:frame];  
  4.     if (self) {  
  5.         // Initialization code.  
  6.         frame.origin.y += 44;  
  7.         frame.size.height -= 44;  
  8.         webView = [[UIWebView alloc] initWithFrame:frame];  
  9.         bar = [[UINavigationBar alloc] initWithFrame:CGRectMake(00, frame.size.width, 44)];  
  10.         UINavigationItem *item = [[UINavigationItem alloc] initWithTitle:nil];  
  11.         UIBarButtonItem *button = [[UIBarButtonItem alloc] initWithTitle:@"Done"   
  12.                                                                    style:UIBarButtonItemStyleDone   
  13.                                                                   target:self   
  14.                                                                   action:@selector(removeSelf)];  
  15.           
  16.         [self addSubview:bar];  
  17.         [self addSubview:webView];  
  18.         [bar pushNavigationItem:item animated:NO];  
  19.         [item setLeftBarButtonItem:button];  
  20.         [item release];  
  21.         [button release];  
  22.           
  23.     }  
  24.     return self;  
  25. }  



















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以通过以下代码给 UIView 添加拖动手势,并限制其移动范围: ```objective-c // 在 viewDidLoad 方法中添加以下代码 UIPanGestureRecognizer *panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(handlePan:)]; [self.view addGestureRecognizer:panGesture]; // 实现手势处理方法 - (void)handlePan:(UIPanGestureRecognizer *)gesture { if (gesture.state == UIGestureRecognizerStateChanged) { CGPoint translation = [gesture translationInView:self.view]; CGRect frame = gesture.view.frame; frame.origin.x += translation.x; frame.origin.y += translation.y; CGFloat navbarHeight = self.navigationController.navigationBar.frame.size.height; CGFloat statusBarHeight = [UIApplication sharedApplication].statusBarFrame.size.height; CGFloat toolbarHeight = self.tabBarController.tabBar.frame.size.height; CGFloat minY = statusBarHeight + navbarHeight; CGFloat maxY = self.view.frame.size.height - toolbarHeight - frame.size.height; frame.origin.y = MAX(minY, MIN(maxY, frame.origin.y)); gesture.view.frame = frame; [gesture setTranslation:CGPointZero inView:self.view]; } } ``` 上面的代码中,我们先创建了一个 UIPanGestureRecognizer 对象,并将其添加到了当前 UIView 上。然后实现了一个 handlePan: 方法用于处理手势。在 handlePan: 方法中,我们首先获取手势的移动距离,然后根据移动距离更新 UIView 的位置。接着,我们计算出导航栏和工具栏的高度,以及 UIView 的最小和最大 Y 坐标,然后通过 MIN 和 MAX 函数限制 UIView 的移动范围。最后,我们将手势的移动距离重置为零,以便下一次移动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值