我的UISegmentedControl分隔符遇到了一个奇怪的错误。当我将手指拖开时,该段会丢失其突出显示的状态图像,但分隔符会保留它。为了实现这一点,我需要拖动大约100px。
向下,目标:
向下,手指被拖离目标:
假设0表示正常状态,1表示选择状态,2表示突出显示状态;我有所有适当的分频器图像,我为每种情况设置它们,即:
00, 01, 02
10, 11, 12
20, 21, 22
其他一切正常,如果我点击并按住目标则没有问题。我不希望用户会点击和拖动,但我宁愿让它解决。有没有人经历过这个?
答案 0 :(得分:2)
无需为“11”和“22”状态提供分频器图像,因为从逻辑上讲,您不能拥有2个相邻的选定分段或2个相邻的突出显示分段。好吧,只有同时点击相邻的段才会突出显示它们,但不太可能。
因此您应该有以下分隔图像:
00, 01, 02
10, --, 12
20, 21, --
此外,对于所有3种不同的状态(正常,选定和突出显示),您还应该有3个背景图像。这些背景图片以及如何创建它们的原因我已经解释了here(在那个解释中我只使用了2个正常和选定状态的背景图像,但是如果你想使用突出显示状态那么你需要添加第3张背景图片)。
以下是显示如何在UISegmentedControl中使用这些图像的图表:
然后使用以下外观方法设置它们:
// Set background images
[segmentedControl setBackgroundImage:background_image_normal
forState:UIControlStateNormal
barMetrics:UIBarMetricsDefault];
[segmentedControl setBackgroundImage:background_image_selected
forState:UIControlStateSelected
barMetrics:UIBarMetricsDefault];
[segmentedControl setBackgroundImage:background_image_highlighted
forState:UIControlStateHighlighted
barMetrics:UIBarMetricsDefault];
// Set divider images 0=Normal 1=Selected 2=Highlighted
[segmentedControl setDividerImage:divider_image_00
forLeftSegmentState:UIControlStateNormal
rightSegmentState:UIControlStateNormal
barMetrics:UIBarMetricsDefault]
[segmentedControl setDividerImage:divider_image_01
forLeftSegmentState:UIControlStateNormal
rightSegmentState:UIControlStateSelected
barMetrics:UIBarMetricsDefault]
[segmentedControl setDividerImage:divider_image_10
forLeftSegmentState:UIControlStateSelected
rightSegmentState:UIControlStateNormal
barMetrics:UIBarMetricsDefault]
[segmentedControl setDividerImage:divider_image_02
forLeftSegmentState:UIControlStateNormal
rightSegmentState:UIControlStateHighlighted
barMetrics:UIBarMetricsDefault]
[segmentedControl setDividerImage:divider_image_20
forLeftSegmentState:UIControlStateHighlighted
rightSegmentState:UIControlStateNormal
barMetrics:UIBarMetricsDefault]
[segmentedControl setDividerImage:divider_image_12
forLeftSegmentState:UIControlStateSelected
rightSegmentState:UIControlStateHighlighted
barMetrics:UIBarMetricsDefault]
[segmentedControl setDividerImage:divider_image_21
forLeftSegmentState:UIControlStateHighlighted
rightSegmentState:UIControlStateSelected
barMetrics:UIBarMetricsDefault]
答案 1 :(得分:0)
一种可能的解决方案是手动子类化UISegmentedControl,并覆盖它以确保在调用UIResponder事件时正确“清理”分隔符状态。可能是该段预期touchesMoved事件发生在与初始touchesBegan相同的边界内。
答案 2 :(得分:0)
别忘了 UIControlStateSelected | UIControlStateHighlighted
// Set background images
UIImage *normalBackgroundImage = [UIImage imageNamed:@"segmented-background-unselected"];
UIImage *selectedBackgroundImage = [UIImage imageNamed:@"segmented-background-selected"];
[self setBackgroundImage:normalBackgroundImage
forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
[self setBackgroundImage:selectedBackgroundImage
forState:UIControlStateSelected barMetrics:UIBarMetricsDefault];
[self setBackgroundImage:normalBackgroundImage
forState:UIControlStateHighlighted barMetrics:UIBarMetricsDefault];
[self setBackgroundImage:selectedBackgroundImage
forState:UIControlStateSelected | UIControlStateHighlighted barMetrics:UIBarMetricsDefault];
// Set divider images
UIImage *buttonImageLeftSelected = [UIImage imageNamed:@"segmented-left-selected"];
UIImage *buttonImageNoneSelected = [UIImage imageNamed:@"segmented-none-selected"];
UIImage *buttonImageRightSelected = [UIImage imageNamed:@"segmented-right-selected"];
[self setDividerImage:buttonImageNoneSelected
forLeftSegmentState:UIControlStateNormal
rightSegmentState:UIControlStateNormal
barMetrics:UIBarMetricsDefault];
[self setDividerImage:buttonImageLeftSelected
forLeftSegmentState:UIControlStateSelected
rightSegmentState:UIControlStateNormal
barMetrics:UIBarMetricsDefault];
[self setDividerImage:buttonImageLeftSelected
forLeftSegmentState:UIControlStateSelected | UIControlStateHighlighted
rightSegmentState:UIControlStateNormal
barMetrics:UIBarMetricsDefault];
[self setDividerImage:buttonImageLeftSelected
forLeftSegmentState:UIControlStateSelected
rightSegmentState:UIControlStateHighlighted
barMetrics:UIBarMetricsDefault];
[self setDividerImage:buttonImageRightSelected
forLeftSegmentState:UIControlStateHighlighted
rightSegmentState:UIControlStateSelected
barMetrics:UIBarMetricsDefault];
[self setDividerImage:buttonImageRightSelected
forLeftSegmentState:UIControlStateNormal
rightSegmentState:UIControlStateSelected | UIControlStateHighlighted
barMetrics:UIBarMetricsDefault];
[self setDividerImage:buttonImageRightSelected
forLeftSegmentState:UIControlStateNormal
rightSegmentState:UIControlStateSelected
barMetrics:UIBarMetricsDefault];