간단 하고 사용 하기 쉬 운 iOS 네 비게 이 션 바 패키지.runtime 속성 제어 인 스 턴 스 코드
본 고 는 주로 여러분 에 게 좋 은 네 비게 이 션 바 제어 도 구 를 소개 합 니 다.코드 를 크게 간소화 하고 시스템 특성 을 유지 할 수 있 으 며 네 비게 이 션 바 를 사용자 정의 하지 않 아 도 되 고 base 를 계승 하지 않 아 도 됩 니 다.
다음은 더 이상 할 말 이 없 으 니 상세 한 소 개 를 살 펴 봅 시다.
UIViewController+YINNav
효과.
@interface UIViewController (YINNav)
/**
appdelegate
- (UIInterfaceOrientationMask)application:(UIApplication *)application supportedInterfaceOrientationsForWindow:(UIWindow *)window{
return [[[NSUserDefaults standardUserDefaults] objectForKey:@"orientation"] integerValue];
}
*/
@property(nonatomic,assign)UIInterfaceOrientationMask y_screenOrientation;
/**
pop
*/
@property (nonatomic) UIViewController *y_popController;
/**
iOS11 NO 。
*/
@property(nonatomic,assign)BOOL y_largeTitleMode;
/**
nav
*/
@property(nonatomic,assign)BOOL y_navLineHidden;
/**
nav
*/
@property(nonatomic,strong)UIView *y_navLine;
/**
[UIColor blackColor]
*/
@property (nonatomic , strong) UIColor *y_navBarTextColor;
/**
[UIColor whiteColor]
*/
@property (nonatomic , strong) UIColor *y_navBarBgColor;
/**
*/
@property (nonatomic , strong) UIImage *y_navBarBgImg;
/**
y_navBarAlpha
*/
@property (nonatomic , assign) CGFloat y_navBarAlpha;
/**
navagationbar navagationbar
*/
@property (nonatomic , assign) BOOL y_navBarHidden;
@end
시스템 방법 과 의 대 비 를 보다.우리 가 시스템 api 를 사용 하여 개발 할 때.일반적인 것 은 그 중 몇 페이지 의 네 비게 이 션 바 스타일 만 다 르 면 부분 설정 은 하나의 원칙 에 따라'페이지 에 들 어 갈 때 수정 하고 페이지 를 떠 날 때 복원'해 야 합 니 다.
예 를 들 어 우리 가 한 페이지 에 들 어가 면 현재 네 비게 이 션 표시 줄 의 배경 색 을 회색 으로 설정 하고 다음 과 같은 방법 을 사용 해 야 합 니 다.
// :
- (void)viewWillAppear:(BOOL)animated{
[super viewWillAppear:animated];
[self.navigationController.navigationBar setBarTintColor:[UIColor grayColor]];
}
// :
- (void)viewWillDisappear:(BOOL)animated{
[super viewWillDisappear:animated];
[self.navigationController.navigationBar setBarTintColor:[UIColor orangeColor]];
}
UIViewController+YINNav 코드 사용:
- (void)viewDidLoad {
[super viewDidLoad];
self.y_navBarBgColor = [UIColor orangeColor];
}
페이지 가 돌아 올 때 표시 할 controller 설정 으로 탐색 표시 줄 을 자동 으로 설정 합 니 다.투명도 그 라 데 이 션 효과
- (void)viewDidLoad {
[super viewDidLoad];
self.y_navBarAlpha = 0.999;// 1 。
self.y_navBarBgColor = [UIColor orangeColor];
}
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
self.y_navBarAlpha = 0.999-(scrollView.contentOffset.y/400.f);
}
탐색 표시 줄 배경 색 설정
- (void)viewDidLoad {
[super viewDidLoad];
self.y_navBarBgColor = [UIColor orangeColor];
}
탐색 표시 줄 배경 그림 설정
- (void)viewDidLoad {
[super viewDidLoad];
//
self.y_navBarBgImg = [UIImage imageNamed:@"app2"];
}
탐색 표시 줄 큰 제목 설정
- (void)viewDidLoad {
[super viewDidLoad];
self.y_largeTitleMode = YES;
}
탐색 표시 줄 숨 기기 설정
- (void)viewDidLoad {
[super viewDidLoad];
self.y_navBarHidden = YES;
}
탐색 표시 줄 의 가 는 선 을 설정 합 니 다.
- (void)viewDidLoad {
[super viewDidLoad];
self. y_navLineHidden = YES;
}
코드 제어 복귀 페이지
- (void)viewDidLoad {
[super viewDidLoad];
// controller navgationcontroller
self.y_popController = [[YINNavAlphaViewController alloc] init];
}
페이지 방향 설정
- (void)viewDidLoad {
[super viewDidLoad];
self. y_screenOrientation = UIInterfaceOrientationMaskLandscapeRight;
}
코드 주소https://github.com/wangyin1/YINNavgationDemo ( 로 컬 다운로드 )
총결산
이상 은 이 글 의 전체 내용 입 니 다.본 논문 의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 참고 학습 가치 가 있 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 댓 글 을 남 겨 주 셔 서 저희 에 대한 지지 에 감 사 드 립 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
상단 탐색 표시 줄 표시 단추 와 검색 상 자 를 유 니 앱 으로 구현 하 는 방법이게 끝 인 줄 알 아?NoNoNo,눈치 빠 른 친구 들 은 제 가 만 든 것 과 설계도 가 차이 가 있다 는 것 을 알 게 되 었 습 니 다.오른쪽 지도 에 icon 이 있 는데 제 가 쓰 지 않 았 습 니 다.만...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.