在导航条的下方加上阴影 navgationbar

本文介绍了一个用于iOS开发的自定义UINavigationBar阴影效果的类别。通过扩展UINavigationBar,开发者可以轻松地为导航栏添加阴影效果,包括设置阴影的颜色、透明度、偏移和半径等属性。

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


工程需要包含 QuartzCore.Framework。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//
// UINavigationBar+JTDropShadow.h
//
// Created by james on 9/20/11.
//
#import
@interface UINavigationBar (JTDropShadow)
- ( void )dropShadowWithOffset:(CGSize)offset
radius :(CGFloat)radius
color :( UIColor *)color
opacity :(CGFloat)opacity;
@end
//
// UINavigationBar+JTDropShadow.m
//
// Created by james on 9/20/11.
//
#import "UINavigationBar+JTDropShadow.h"
#import
@implementation UINavigationBar (JTDropShadow)
- ( void )dropShadowWithOffset:(CGSize)offset
radius :(CGFloat)radius
color :( UIColor *)color
opacity :(CGFloat)opacity {
// Creating shadow path for better performance
CGMutablePathRef path = CGPathCreateMutable();
CGPathAddRect(path, NULL , self .bounds );
self .layer .shadowPath = path;
CGPathCloseSubpath(path);
CGPathRelease(path);
self .layer .shadowColor = color .CGColor ;
self .layer .shadowOffset = offset;
self .layer .shadowRadius = radius;
self .layer .shadowOpacity = opacity;
// Default clipsToBounds is YES, will clip off the shadow, so we disable it.
self .clipsToBounds = NO ;
}
@end
//用法如下
- ( void )viewDidLoad {
[ super viewDidLoad ];
...
[ self .navigationController .navigationBar dropShadowWithOffset :CGSizeMake( 0 , 3 )
radius : 1
color :[ UIColor darkGrayColor ]
opacity : 1 ];
...
}
Tag
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值