UITableView enhancer for rich content cells. FancyDots provide a beautiful way to see the position in a table view with high cells and an easy navigation interaction.
Just drag and drop the .h and .m files and the ressource folders. Don't forget to check the copy files box. In code, .xib file or storyboard, create an MLFancyDots view (inherits from UIView) of the size you want. The dots will be vertical and centered horizontally. Set the delegate property of the MLFancyDots view.
- (NSInteger) numberOfDotsInFancyDots:(MLFancyDots *)fancyDots
{
return [_cellsData count]; // return number of rows in table view, doesn't support mutiple sections yet
}
- (CGSize) imageSizeForFancyDots:(MLFancyDots *)fancyDots
{
return CGSizeMake(29, 29);
}
- (NSString *) fancyDots:(MLFancyDots *)fancyDots imageNameForSelectedDotAtIndex:(NSInteger)index
{
return @"rond1.png";
}
- (NSString *) fancyDots:(MLFancyDots *)fancyDots imageNameForDefaultDotAtIndex:(NSInteger)index
{
return @"rond3.png";
}
/* optional - just use this if you want particular dots (like use red dots for some special cells)
- (NSString *) fancyDots:(MLFancyDots *)fancyDots specialImageNameForDotAtIndex:(NSInteger)index
selected:(BOOL)selected
{
NSDictionary *seq = [_cellsData objectAtIndex:index];
if ([self isParticular:seq]) {
if (selected)
return @"rond6.png";
else
return @"rond2.png";
}
return nil;
}
//*/
/* optional
- (NSString *) fancyDots:(MLFancyDots *)fancyDots textForDotAtIndex:(NSInteger)index
{
return @"hello world";
}
//*/
/* optional
- (void) fancyDots:(MLFancyDots *)fancyDots didSelectDotAtIndex:(NSInteger)index
{
NSIndexPath *newSelectedRow = [NSIndexPath indexPathForRow:index inSection:0];
[self.tableView scrollToRowAtIndexPath:newSelectedRow atScrollPosition:UITableViewScrollPositionTop animated:YES];
}
//*/