2012-04-19 11 views
6

Ho appena iniziato a giocare con il modello di visualizzazione Dettagli principali in Xcode 4.3 e sto cercando di cambiare il colore di sfondo del master e impostarlo su un gradiente di colore. Ecco cosa ho provato:iOS UITableView: assegna il colore di sfondo come gradiente usando CAGradientLayer

Colors.m

#import "Colors.h" 

@implementation Colors 

+ (UIColor *) navigationMenuGradientTop 
{ 
    return [UIColor colorWithRed:213.0f/255.0f green:91.0f/255.0f blue:92.0f/255.0f alpha:1.0f]; 
} 

+ (UIColor *) navigationMenuGradientBottom 
{ 
    return [UIColor colorWithRed:188.0f/255.0f green:0.0f/255.0f blue:1.0f/255.0f alpha:1.0f];  
} 

+ (CAGradientLayer *) navigationMenuGradient 
{ 
    NSArray *colors = [NSArray arrayWithObjects:(id)self.navigationMenuGradientTop, self.navigationMenuGradientBottom, nil]; 
    CAGradientLayer *gradientLayer = [CAGradientLayer layer]; 
    gradientLayer.colors = colors; 

    return gradientLayer; 
} 
@end 

MasterViewController.m

import "Colors.h" 

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath 
{ 
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell"]; 

    CAGradientLayer *bgLayer = [Colors navigationMenuGradient]; 
    bgLayer.frame = tableView.bounds; 
    [tableView.layer insertSublayer:bgLayer atIndex:0]; 

    return cell; 
} 

Su esecuzione ottengo il seguente errore nel main - Thread 1: EXC_BAD_ACCESS (code=1, address=0xxxxxxxx)

int main(int argc, char *argv[]) 
{ 
    @autorelasespool { 
     return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); 
    } 
} 

I ho aggiunto anche il framework QuartzCore al progetto . Cosa mi manca qui? e in che direzione dovrei entrare generalmente quando si verificano tali errori (perché la compilazione è riuscita, l'app sembra essersi arrestata qui)?

+0

possibile duplicato del [pendenze su UIView e UILabels su iPhone] (http://stackoverflow.com/questions/422066/gradients-on-uiview-and-uilabels-on-iphone) –

risposta

22
UIView *view = [[[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 100)] autorelease]; 
CAGradientLayer *gradient = [CAGradientLayer layer]; 
gradient.frame = view.bounds; 
gradient.colors = [NSArray arrayWithObjects:(id)[[UIColor blackColor] CGColor], (id)[[UIColor whiteColor] CGColor], nil]; 
[view.layer insertSublayer:gradient atIndex:0]; 

da: Gradients on UIView and UILabels On iPhone

questo codice può aiutare il vostro problema.

+3

Ok così sembra che 'CAGradientLayer' non funziona con un array di' UIColor'. Invece è necessaria una matrice 'CGColor'. Un rapido sguardo nella documentazione lo ha confermato. http://developer.apple.com/library/ios/#documentation/GraphicsImaging/Reference/CAGradientLayer_class/Reference/Reference.html – vikmalhotra

+0

non ho mai usato quel colore, quindi non ne ho idea, ma stavo cercando di risolvere il tuo problema –

+1

aggiungi .CGColor alla fine del blocco [UIColor]. es. '[UIColor blackColor] .CGColor' – Moe

2

Per aggiungere un gradiente di sfondo ad una vista ho seguito il tutorial a questo link:

http://danielbeard.wordpress.com/2012/02/25/gradient-background-for-uiview-in-ios/

Nel mio caso ho avuto un UITableView e voleva il gradiente di essere in lo sfondo. Quando ho usato il codice qui sotto dal link il mio tableview è scomparso.

-(void) ViewWillAppear:(BOOL) animated { 
CAGradientLayer *bgLayer = [BackgroundLayer blueGradient]; 
bgLayer.frame = self.view.bounds; 
[self.view.layer insertSublayer:bgLayer atIndex:0]; 
} 

Nella modifica del mio codice come di seguito, è stato possibile avere un gradiente di sfondo e una vista tabella contemporaneamente.

-(void) ViewDidAppear:(BOOL) animated { 
CAGradientLayer *bgLayer = [BackgroundLayer blueGradient]; 
bgLayer.frame = self.view.bounds; 
[self.tableView.layer insertSublayer:bgLayer atIndex:0]; 
} 
+0

Non combina solo le altre due risposte in una? – paqogomez

+0

Sembra inoltre che tu disponga di un altro account che utilizzi per aumentare le tue preferenze. – paqogomez

Problemi correlati