いいえ、ループが正しく設定されていません。スワイプするたびにループするべきではありません。ループ全体がスワイプごとに実行されます。これにより、すべての色がステップスルーされ、ビューの色がその色に設定されます。当然、最後の色が見られる色です。
代わりに、インデックスをメモリに保持し、スワイプするたびにインクリメント/デクリメントします。スワイプするたびに、ビューの色を更新します。
// Declare two new properties in the class extension
@interface MyClass ()
@property (nonatomic) NSInteger cursor;
@property (nonatomic, strong) NSArray *colorArray;
...
@end
//In your designated initializer (may not be init depending on your superclasses)
//Instantiate the array of colors to choose from.
- (id)init {
    self = [super init];
    if (self) {
        _colorArray = @[ [UIColor whiteColor], [UIColor blueColor], [UIColor redColor] ];
    }
    return self;
}
//Implement your gesture recognizer callback.
//This handles swipes to the left and right. Left swipes advance cursor, right swipes decrement
- (void)singleSwipe:(UISwipeGestureRecognizer *)recognizer
{
    UISwipeGestureRecognizerDirection direction = [recognizer direction];
    if (direction == UISwipeGestureRecognizerDirectionLeft) {
        // Increment cursor
        self.cursor += 1;
        // If cursor is outside bounds of array, wrap around.
        // Chose not to use % to be more explicit.
        if (self.cursor >= [self.colorArray count]) {
            self.cursor = 0;
        }
    }
    else if (direction == UISwipeGestureRecognizerDirectionRight) {
        // Decrement cursor
        self.cursor -= 1;
        // If outside bounds of array, wrap around.
        if (self.cursor < 0) {
            self.cursor = [self.colorArray count] - 1;
        }
    }
    // After adjusting the cursor, we update the color.
    [self showColorAtCursor];
}
// Implement a method to change color
- (void)showColorAtCursor
{
    UIColor *c = self.colorArray[self.cursor];
    _noteView.aTextView.backgroundColor = c;
}