亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS 控件封裝(又名擰螺絲)之排序按鈕的開發

2019-10-21 18:22:03
字體:
來源:轉載
供稿:網友

前言

排序按鈕是實際開發中比較常見的一種控件,最近我也遇到了,今天簡單分享下。

雖然功能簡單,但是保證你看了不虧,尤其是對UI這塊比較薄弱的同學來說。

OK,先看圖:

iOS,控件封裝,排序按鈕

簡單描述一下:

按鈕一共有三種狀態:非選中、選中升序、選中降序。

iOS,控件封裝,排序按鈕

按鈕的三種狀態

點擊按鈕時有兩種情況:

  1. 按鈕原本處于非選中狀態,點擊,切換到選中狀態,其狀態變為升序。
  2. 按鈕原本就處于選中狀態,再點擊一下,則切換其排序狀態(升變降、降變升)。

不同狀態對應不同的icon,如果沒有UI,可以去iconfont 找圖標,輸入關鍵詞如“上下箭頭”就可以找到你需要的icon。

基本思路

繼承UIButton,直接在button上放view,設置約束,根據按鈕的狀態設置對應的圖片。

PS:自定義按鈕最靈活的做法就是直接在button上放view(在不需要糾結內存和view層級的情況下),簡單粗暴、隨心所欲。

完整代碼

.h文件:

#import <UIKit/UIKit.h>@interface CQSortButton : UIButton/** 按鈕文本 */@property (nonatomic, copy) NSString *title;/** 是否是升序 */@property (nonatomic, assign, readonly, getter=isAscending) BOOL ascending;@end

.m文件:

#import "CQSortButton.h"@interface CQSortButton ()/** 文本label */@property (nonatomic, strong) UILabel *cq_titleLabel;/** 箭頭imageView */@property (nonatomic, strong) UIImageView *cq_arrowImageView;@end@implementation CQSortButton#pragma mark - 構造方法- (instancetype)initWithFrame:(CGRect)frame { if (self = [super initWithFrame:frame]) {  [self setupUI]; } return self;}#pragma mark - UI搭建- (void)setupUI { self.layer.borderColor = [UIColor blackColor].CGColor; self.layer.borderWidth = 1; // 文本和圖片的父view UIView *contentView = [[UIView alloc] init]; [self addSubview:contentView]; contentView.userInteractionEnabled = NO; [contentView mas_makeConstraints:^(MASConstraintMaker *make) {  make.top.bottom.centerX.mas_equalTo(self);  make.left.mas_greaterThanOrEqualTo(self).mas_offset(3);  make.right.mas_lessThanOrEqualTo(self).mas_offset(-3); }]; // 文本 self.cq_titleLabel = [[UILabel alloc] init]; [contentView addSubview:self.cq_titleLabel]; self.cq_titleLabel.font = [UIFont boldSystemFontOfSize:13]; self.cq_titleLabel.adjustsFontSizeToFitWidth = YES; [self.cq_titleLabel mas_makeConstraints:^(MASConstraintMaker *make) {  make.top.bottom.left.mas_offset(0); }]; // 圖片 self.cq_arrowImageView = [[UIImageView alloc] init]; [contentView addSubview:self.cq_arrowImageView]; self.cq_arrowImageView.image = [UIImage imageNamed:@"up_down"]; [self.cq_arrowImageView mas_makeConstraints:^(MASConstraintMaker *make) {  make.size.mas_equalTo(CGSizeMake(20, 20));  make.centerY.mas_equalTo(contentView);  make.left.mas_equalTo(self.cq_titleLabel.mas_right);  make.right.mas_equalTo(contentView); }];}#pragma mark - 賦值選中狀態- (void)setSelected:(BOOL)selected { //// 注意: //// selected 表示你要賦值的狀態 //// super.selected 表示當前處于的狀態 if (selected) { // 即將設置成選中狀態  if (super.selected) { // 如果原本就處于選中狀態   // 那么就切換篩選狀態   _ascending = !_ascending;   if (_ascending) {    // 升序    self.cq_arrowImageView.image = [UIImage imageNamed:@"red_arrow_up"];   } else {    // 降序    self.cq_arrowImageView.image = [UIImage imageNamed:@"red_arrow_down"];   }  } else { // 如果之前不是選中狀態   // 那么設置成選中的默認排序狀態:升序   _ascending = YES;   self.cq_arrowImageView.image = [UIImage imageNamed:@"red_arrow_up"];  } } else { // 即將設置成非選中狀態  // 設置成非選中狀態的圖片  self.cq_arrowImageView.image = [UIImage imageNamed:@"up_down"]; } // 最后再賦值 [super setSelected:selected];}#pragma mark - 賦值文本- (void)setTitle:(NSString *)title { _title = title; self.cq_titleLabel.text = title;}@end

使用:

- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. NSArray *titleArray = @[@"同比", @"銷售額", @"
注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品爽黄69| 亚洲第一天堂av| 日本亚洲欧美成人| 久久久www成人免费精品张筱雨| 中文字幕亚洲欧美日韩在线不卡| 日韩精品福利在线| 亚洲 日韩 国产第一| 中文字幕av一区二区| 欧美影院成年免费版| 8x拔播拔播x8国产精品| 国产精品精品久久久| 国产精品毛片a∨一区二区三区|国| 欧美老少配视频| 最近的2019中文字幕免费一页| 国产欧美一区二区三区久久人妖| 亚洲国产精品成人一区二区| 国产精品白丝av嫩草影院| 亚洲乱码一区av黑人高潮| 国产网站欧美日韩免费精品在线观看| 亚洲美女在线视频| 国产精品视频精品视频| 中文字幕日韩专区| 97国产真实伦对白精彩视频8| 国产剧情久久久久久| 国产精品旅馆在线| www.亚洲免费视频| 亚洲欧美中文字幕在线一区| 亚洲免费一在线| 成人精品在线观看| 久久久久久久一区二区| 精品久久香蕉国产线看观看gif| 在线观看免费高清视频97| 国产一区二区三区在线观看网站| 久久影视电视剧凤归四时歌| 亚洲精品一区二区三区婷婷月| 亚洲精品成人久久电影| 久久久女人电视剧免费播放下载| 色综合久久久久久中文网| 国产日韩欧美日韩| 国产精品美女在线观看| 亚洲黄页网在线观看| 亚洲第一区中文99精品| 成人精品一区二区三区电影免费| 亚洲综合一区二区不卡| 亚洲白虎美女被爆操| 尤物yw午夜国产精品视频明星| 国产一区二区在线免费视频| 午夜精品久久久久久久99热浪潮| 欧美精品videosex性欧美| 96pao国产成视频永久免费| 日韩在线视频中文字幕| 日韩中文av在线| 青草成人免费视频| 欧美一区第一页| 亚洲在线免费观看| 亚洲美女av电影| 亚洲人成网站在线播| 91sao在线观看国产| 亚洲精品综合久久中文字幕| 欧美日韩ab片| 久久久久久综合网天天| 不卡av电影在线观看| 在线精品91av| 91精品国产综合久久香蕉最新版| 欧美精品videos另类日本| 国产精品揄拍一区二区| 综合欧美国产视频二区| 欧美与黑人午夜性猛交久久久| 第一福利永久视频精品| 国产精品视频99| 亚洲加勒比久久88色综合| 国产精品免费一区豆花| 欧美日韩性视频在线| 日韩国产欧美精品在线| 一区二区三区在线播放欧美| 精品国产区一区二区三区在线观看| 91最新在线免费观看| 国产又爽又黄的激情精品视频| 亚洲成人网久久久| 欧美极品美女视频网站在线观看免费| 欧美成人精品激情在线观看| 久久免费视频在线观看| 欧美刺激性大交免费视频| 欧美激情久久久久| 日本精品免费一区二区三区| 精品日韩美女的视频高清| 亚洲精品国产美女| 欧美精品在线网站| 日韩国产在线看| 欧美性xxxxxxx| 久久天天躁狠狠躁老女人| 亚洲国产精彩中文乱码av| 久久精品亚洲94久久精品| 精品国产一区av| 国产一区二区三区在线播放免费观看| 热久久视久久精品18亚洲精品| 国产69精品99久久久久久宅男| 亚洲人成在线播放| 最好看的2019的中文字幕视频| 97精品国产97久久久久久免费| 欧美精品在线第一页| 欧美日韩一区二区三区在线免费观看| 久久精品中文字幕免费mv| 亚洲欧美日韩国产成人| 91产国在线观看动作片喷水| 45www国产精品网站| 国产亚洲一区二区在线| 日韩在线视频二区| 亚洲男人天堂2024| 久久免费精品日本久久中文字幕| 久久免费精品视频| 欧美激情奇米色| 国产欧美精品一区二区| 亚洲午夜色婷婷在线| 精品国产一区二区在线| 欧美一级成年大片在线观看| 久久国产精品久久精品| 伊人伊成久久人综合网站| 精品亚洲一区二区三区| 亚洲一区二区免费| 国产激情久久久久| 国产97在线亚洲| 91免费看视频.| 日韩中文字幕国产| 欧美激情亚洲激情| 亚洲欧美一区二区三区情侣bbw| 久久精品久久久久久国产 免费| 日韩成人黄色av| 久久久久久久久综合| 57pao国产成人免费| 欧美性少妇18aaaa视频| 高清欧美性猛交xxxx黑人猛交| 亚洲一区二区中文| 国产日韩欧美中文在线播放| 成人有码在线视频| 成人av资源在线播放| 亚洲天堂av高清| 欧美精品第一页在线播放| 久久精视频免费在线久久完整在线看| 欧美裸身视频免费观看| 中文字幕精品影院| 欧美激情一区二区三级高清视频| 欧美亚洲伦理www| 亚洲欧美精品suv| 欧美美女18p| 欧美激情综合色综合啪啪五月| 国产成人一区二区三区电影| 视频在线观看99| 午夜精品蜜臀一区二区三区免费| 日韩一区二区精品视频| 欧美性猛交xxxx黑人| 欧美亚洲视频一区二区| 日韩中文字幕在线观看| 91久久久久久久一区二区| 欧美午夜精品久久久久久人妖| www.久久久久| 欧美wwwwww| 91中文精品字幕在线视频| 亚洲区在线播放| 久久91亚洲精品中文字幕| 91人人爽人人爽人人精88v| 精品久久久久久亚洲精品| 色偷偷噜噜噜亚洲男人| 亚洲欧美在线免费|