你的位置:首页 > 操作系统

[操作系统]IOS的segmentedControl(分段器控件)的一些常用属性


#pragma mark - 创建不同的分段器

    //初始化方法:传入的数组可以是字符串也可以是UIImage对象的图片数组

    UISegmentedControl *mysegmented = [[UISegmentedControl alloc] initWithItems:@[@"左边",@"我是中间",@"右边"]];

    mysegmented.frame = CGRectMake(50, 200, kScreenWidth-100, 40);

    [self.view addSubview: mysegmented];

    

    //第二种创建方式

    UISegmentedControl *mysegmented2 = [[UISegmentedControl alloc] initWithFrame:CGRectMake(100, 200, 300, 40)];

    //animated为NO即表示不是即时修改,等点击事件结束后再响应

    [mysegmented2 insertSegmentWithTitle:@"聊天" atIndex:1 animated:YES];

    [mysegmented2 insertSegmentWithTitle:@"通话" atIndex:0 animated:YES];

//    [self.view addSubview:mysegmented2];

    

    //创建一个图片数组,用图片来作为分段器的元素

    NSArray *imageArray = @[[UIImage imageNamed: @"prev"],[UIImage imageNamed: @"next"]];

    UISegmentedControl *yoursegmented = [[UISegmentedControl alloc] initWithItems:imageArray];

    yoursegmented.frame = CGRectMake(100, 450, kScreenWidth-200, 65);

    [self.view addSubview: yoursegmented];

 

    

    

#pragma mark - 重设标签标题和获取标签标题

    [mysegmented setTitle: @"我是修改过的标签" forSegmentAtIndex:1];

    NSString *titleString = [mysegmented titleForSegmentAtIndex: 1];

    NSLog(@"%@", titleString);

    //也可以重新设置图片标签和获取标签图片

    //- (void)setImage:(UIImage *)image forSegmentAtIndex:(NSUInteger)segment;

    //- (UIImage *)imageForSegmentAtIndex:(NSUInteger)segment;

    

 

 /* 以下是在ios开发中,对segmentedControl控件的一些属性的用法解析,只能用手机查看不能自己运行的也没有关系,以下内容是带图片的。*/

 

#pragma mark - 设置标签的颜色(默认为blue)以及图片

    //背景颜色

    mysegmented.backgroundColor = [UIColor greenColor];

    //文字的颜色,边框的颜色,以及选中的标签的颜色

    mysegmented.tintColor = [UIColor redColor];

    //设置标签的背景图片,还可以获取分段器的背景图片

    //[mysegmented setBackgroundImage:[UIImage imageNamed:@"prev"] forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];

    //(设置的是整个分段器的背景图片),UIBarMetrics是一个枚举,default默认背景图片充满整个分段器

    

 

 

 

#pragma mark - 设置分段器的分割线的图片(同样的,也可以获取图片)

    // - (void)setDividerImage:(UIImage *)dividerImage forLeftSegmentState:(UIControlState)leftState rightSegmentState:(UIControlState)rightState barMetrics:(UIBarMetrics)barMetrics

 

 

#pragma mark - 选中状态(若不指定下标,那么根据创建的items顺序,下标从0开始增长)

    mysegmented.selectedSegmentIndex = 0;

    yoursegmented.selectedSegmentIndex = 1;

 

 

 

 

#pragma mark - numberOfSegments,获取标签的个数,只读的

    NSInteger i = mysegmented.numberOfSegments;

    NSLog(@"一共有%ld个标签",i);

 

 

    

#pragma mark - 设置标签宽度是否随内容自适应(设置为NO则表示所有标签宽度一致为最大的宽度)

    mysegmented.apportionsSegmentWidthsByContent = NO;

    

#pragma mark - 插入文字标签或图片在index位置

    [mysegmented insertSegmentWithTitle: @"我是插入的标签" atIndex:2 animated:YES];

    [yoursegmented insertSegmentWithImage: [UIImage imageNamed: @"next"] atIndex:0 animated:YES];    

 

 

#pragma mark - 根据索引删除标签或删除所有标签

    [mysegmented removeSegmentAtIndex: 1 animated: YES];

    //[mysegmented removeSegmentAtIndex: 1 animated: NO];

    //删除所有标签 [mysegmented removeAllSegments];

 

 

 

 

#pragma mark - 根据索引设置相应标签宽度和获取标签宽度

    //若setWidth设置为0.0,则默认为自适应宽度

    [yoursegmented setWidth: 50.0 forSegmentAtIndex:0];

    //获取标签宽度

    //- (CGFloat)widthForSegmentAtIndex:(NSUInteger)segment;

 

 

 

 

#pragma mark - 设置标签内容的偏移量和获取偏移量

    [mysegmented setContentOffset: CGSizeMake(20.0, 0) forSegmentAtIndex:0];

    //获取偏移量

    //- (CGSize)contentOffsetForSegmentAtIndex:(NSUInteger)segment;

    

 

 

#pragma mark - 根据索引设置标签是否有效(默认有效)和获取是否有效

    //- (void)setEnabled:(BOOL)enabled forSegmentAtIndex:(NSUInteger)segment;

    //- (BOOL)isEnabledForSegmentAtIndex:(NSUInteger)segment;

    

 

#pragma mark - 点击事件(可以带参数)

    [mysegmented addTarget:self action:@selector(segmentedAction) forControlEvents:UIControlEventValueChanged];

    //这里需创建另外的视图控制器进行演示

}

 

//点击事件

- (void) segmentedAction{

    FirstViewController *firstVC = [[FirstViewController alloc] init];

    [self.view addSubview:firstVC.view];

    //从父视图上移除 [_firstVC.view removeFromSuperview];

}

 

 

 

/*

  以上是我自己总结的分段器控件的一些基本属性,剪掉图片,以上代码可以直接复制粘贴到自己的工程中运行,可自行查看和修改结果。对以上有异议或者想和我一起讨论的,可以加我的qq 78928861,大家一起讨论,一起学习。

*/