Pergunta

Eu estou usando http://github.com/facebook/three20 no meu aplicativo iPhone . Eu segui as instruções para incluir o quadro no meu projeto. Eu tenho verificado que duas vezes agora (nas recomendações de pessoas no grupo google e IRC). Eu recebo o seguinte erro quando algumas das tentativas de código Three20 usar um seletor catalogado no UIView:

- [TTSearchTextField ancestorOrSelfWithClass:]: selector não reconhecido enviada à instância 0x3a85ee0'

Esta excepção é acionado quando eu tocar o campo de texto.

Aqui está o kicker para mim, se eu não atribuir uma fonte de dados para o TTSearchTextField não provocar o erro. Então, logicamente I figurado ele deve ser meu dataSource.

  1. Eu coloquei um ponto de ruptura em cada função na minha fonte de dados.
  2. executou o programa, como esperado init foi chamado e os delegados de assessor foi chamado.
  3. Tapped o campo de texto, há chamadas para a minha fonte de dados e a exceção de tempo de execução ocorre.

Eu estou perplexo sobre este. Eu nunca tive problemas usando libs externos com Catálogos neles antes. Eu posso fornecer mais informações sobre a configuração do projeto, basta perguntar para fins específicos uma vez que há um pouco de informação lá.

código que estou usando a criar o TTSearchTextField:

// setup Country
self.searchFieldCountry = [[TTSearchTextField alloc]initWithFrame:CGRectMake(156, 145, 146, 37)];
self.searchFieldCountry.borderStyle = UITextBorderStyleRoundedRect;
self.searchFieldCountry.placeholder = @"Country";
self.searchFieldCountry.autocapitalizationType = UITextAutocapitalizationTypeNone;
OLLocationSearchDataSource *ds = [[OLLocationSearchDataSource alloc]init];
self.searchFieldCountry.dataSource = ds;
[self.view addSubview:self.searchFieldCountry];
[ds release];

Código para o meu DataSource:

#import "OLLocation.h"
#import "AppSession.h"

@implementation OLLocation

@synthesize locationData = _locationData;

@synthesize locationMode,country,region;

- (NSMutableArray*)delegates {
    if (!_delegates) {
        _delegates = TTCreateNonRetainingArray();
    }
    return _delegates;
}

- (BOOL)isLoadingMore {
    return NO;
}

- (BOOL)isOutdated {
    return NO;
}

- (BOOL)isLoaded {
    return !!_AllLocationData;
}

- (BOOL)isLoading {
    return NO;
}

- (BOOL)isEmpty {
    return !_AllLocationData.count;
}

- (void)load:(TTURLRequestCachePolicy)cachePolicy more:(BOOL)more {
}

- (void)invalidate:(BOOL)erase {
}

- (void)cancel {
    // cancel a search if possible
}

- (void)loadNames {
    _AllLocationData = [[AppSession getAppSession] getCountries];
}

- (void)search:(NSString*)text {
    [self cancel];

    self.locationData = [NSMutableArray array];

    if (text.length) {
        text = [text lowercaseString];
        for (NSString* name in _AllLocationData) {
            if ([[name lowercaseString] rangeOfString:text].location == 0) {
                [_locationData addObject:name];
            }
        }
    }
}

- (void)dealloc {
    [super dealloc];
}

@end

@implementation OLLocationSearchDataSource

@synthesize locations = _locations;

-(id)init {
    if (self = [super init]) {
        _locations = [[OLLocation alloc] init];
        _locations.locationMode = OLLocationModeCountry;
        self.model = _locations;
    }
    return self;
}

-(void)dealloc {
    TT_RELEASE_SAFELY(_locations);
    [super dealloc];
}

///////////////////////////////////////////////////////////////////////////////////////////////////
// TTTableViewDataSource

- (void)tableViewDidLoadModel:(UITableView*)tableView {
    self.items = [NSMutableArray array];

    for (NSString* name in _locations.locationData) {
        TTTableItem* item = [TTTableTextItem itemWithText:name URL:@"http://google.com"];
        [_items addObject:item];
    }
}

- (void)search:(NSString*)text {
    [_locations search:text];
}

- (NSString*)titleForLoading:(BOOL)reloading {
    return @"Searching...";
}

- (NSString*)titleForNoData {
    return @"No names found";
}

@end
Foi útil?

Solução

Eu não acho que é a sua fonte de dados. -ancestorOrSelfWithClass: é um método categoria que se estende UIView e é adicionado em UIViewAdditions.h. A razão que você está recebendo o erro ao adicionar sua fonte de dados é provavelmente que qualquer código que envia a mensagem -ancestorOrSelfWithClass: provavelmente não é chamado se a fonte de dados não está atribuído.

Ao compilar bibliotecas estáticas para inclusão em aplicações para iPhone, sob 2.x você necessários para adicionar -ObjC a seus Outras Bandeiras Linker para garantir que os métodos categoria foram ligados à biblioteca. Em 3.x, que não parece funcionar corretamente, então -all_load necessário para ser adicionado, bem como para as outras opções vinculador.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top