Cómo cambiar la altura de UIPickerView

Respuestas:

54

Parece obvio que Apple no invita particularmente a limpiar con la altura predeterminada de la UIPickerView, pero he descubierto que puede lograr un cambio en la altura de la vista tomando el control completo y pasando un tamaño de fotograma deseado en el momento de la creación, por ejemplo:

smallerPicker = [[UIPickerView alloc] initWithFrame:CGRectMake(0.0, 0.0, 320.0, 120.0)];

Descubrirá que en varias alturas y anchos, hay fallas visuales. Obviamente, estos fallos tendrían que solucionarse de alguna manera o elegir otro tamaño que no los presente.

danielpunkass
fuente
2
¿Esto funciona para ti? Todas las UIPickerViews que instalo parecen estar bloqueadas a una altura de 215 ...
Andy Bourassa
Esto funciona para mi. ¿Está especificando la altura acortada en el método initWithFrame, como describí? Tienden a luchar para mantenerse a cierta altura, pero una vez que inicialicé con un marco corto, funcionó. Si aún no puede hacer que funcione, veré si puedo extraer una muestra.
danielpunkass
¿Existe algún control de terceros que permita cambiar el tamaño?
cfischer
1
Esto funcionó. 4.3. Inicio con frame y setframe antes de la primera aparición.
griotspeak
2
Estuve atrapado en esto por un tiempo. Es IMPORTANTE tener en cuenta que DEBE iniciar con frame o setframe antes de la primera aparición o obtendrá fallos visuales.
w.donahue
46

Ninguno de los enfoques anteriores funciona en iOS 4.0

La altura de pickerView ya no es redimensionable. Hay un mensaje que se descarga a la consola si intenta cambiar el marco de un selector en 4.0:

-[UIPickerView setFrame:]: invalid height value 66.0 pinned to 162.0 

Terminé haciendo algo bastante radical para obtener el efecto de un selector más pequeño que funciona tanto en OS 3.xx como en OS 4.0. Dejé que el selector tuviera el tamaño que el SDK decida que debería ser y, en su lugar, hice una ventana transparente de corte en mi imagen de fondo a través de la cual el selector se vuelve visible. Luego, simplemente coloque el selector detrás (orden Z) de mi UIImageView de fondo para que solo una parte del selector sea visible, lo que está dictado por la ventana transparente en mi fondo.

bhavinb
fuente
44

Solo hay tres alturas válidas para UIPickerView (162.0, 180.0 and 216.0).

Puede utilizar las funciones CGAffineTransformMakeTranslationy CGAffineTransformMakeScalepara ajustar correctamente el selector a su conveniencia.

Ejemplo:

CGAffineTransform t0 = CGAffineTransformMakeTranslation (0, pickerview.bounds.size.height/2);
CGAffineTransform s0 = CGAffineTransformMakeScale       (1.0, 0.5);
CGAffineTransform t1 = CGAffineTransformMakeTranslation (0, -pickerview.bounds.size.height/2);
pickerview.transform = CGAffineTransformConcat          (t0, CGAffineTransformConcat(s0, t1));

El código anterior cambia la altura de la vista del selector a la mitad y la vuelve a colocar en la posición exacta (Izquierda-x1, Arriba-y1) .

JRSee
fuente
1
Gran respuesta. Solo tenga en cuenta que para cambiar la altura del selector no es necesario utilizar la traducción: pickerview.transform = CGAffineTransformMakeScale (1.0, 0.5);
Borzh
2
Gracias. Parece cierto, pero ¿hay alguna documentación de Apple sobre las alturas válidas?
Eric Chen
40

Tratar:

pickerview.transform = CGAffineTransformMakeScale(.5, 0.5);
vijay adhikari
fuente
2
Sé que llego tarde a la fiesta aquí, y tal vez existan mejores métodos ahora para hacer esto, pero esto funcionó para mí.
Hanny
¡Funciona genial! Para Swift (iOS 10) es: statePicker.transform = CGAffineTransform (scaleX: 0.8, y: 0.8)
Meshach
25

En iOS 4.2 y 4.3 funciona lo siguiente:

UIDatePicker *datePicker = [[UIDatePicker alloc] init];
datePicker.frame = CGRectMake(0, 0, 320, 180);
[self addSubview:datePicker];

Lo siguiente no funciona:

UIDatePicker *datePicker = [[UIDatePicker alloc] initWithFrame:CGRectMake(0, 0, 320, 180)];
[self addSubview:datePicker];

Tengo una aplicación que está en la tienda de aplicaciones con un selector de fecha de 3 líneas. Pensé que el cambio de altura podría haberse evitado porque ve el texto debajo del borde del selector de fecha, pero esto también le sucede al selector de fecha de altura 216 normal.

Cual es el error? Tu invitado es tan bueno como el mío.

También hay 3 alturas válidas para UIDatePicker(y UIPickerView) 162.0, 180.0 y 216.0. Si establece una UIPickerViewaltura para cualquier otra cosa, verá lo siguiente en la consola al depurar en un dispositivo iOS.

2011-09-14 10:06:56.180 DebugHarness[1717:707] -[UIPickerView setFrame:]: invalid height value 300.0 pinned to 216.0
mmorris
fuente
14

A partir de iOS 9, puede cambiar libremente UIPickerViewel ancho y el alto. No es necesario utilizar los trucos de transformación mencionados anteriormente.

rounak
fuente
es necesario determinar cómo agregar un inputAccessoryView a un UIPickerView de mayor tamaño.
DogCoffee
¿Me importa compartir cómo?
inmanl
10

Descubrí que puede editar el tamaño de UIPickerView, pero no con el generador de interfaces. abra el archivo .xib con un editor de texto y establezca el tamaño de la vista del selector como desee. El generador de interfaces no restablece el tamaño y parece funcionar. Estoy seguro de que Apple bloqueó el tamaño por una razón, así que tendrás que experimentar con diferentes tamaños para ver qué funciona.


fuente
7

Ventajas:

  1. Hace que setFrame se UIPickerViewcomporte como debería
  2. Sin transformar código dentro de su UIViewController
  3. Funciona dentro viewWillLayoutSubviewspara cambiar la escala / posicionarUIPickerView
  4. Funciona en el iPad sin UIPopover
  5. La superclase siempre recibe una altura válida
  6. Funciona con iOS 5

Desventajas:

  1. Requiere que subclases UIPickerView
  2. Requiere el uso de pickerView viewForRowpara deshacer la transformación de las subVistas
  3. Es posible que las animaciones UIA no funcionen

Solución:

Subclase UIPickerView y sobrescriba los dos métodos usando el siguiente código. Combina subclases, altura fija y el enfoque de transformación.

#define FIXED_PICKER_HEIGHT 216.0f
- (void) setFrame:(CGRect)frame
{
    CGFloat targetHeight = frame.size.height;
    CGFloat scaleFactor = targetHeight / FIXED_PICKER_HEIGHT;
    frame.size.height = FIXED_PICKER_HEIGHT;//fake normal conditions for super
    self.transform = CGAffineTransformIdentity;//fake normal conditions for super
    [super setFrame:frame];
    frame.size.height = targetHeight;
    CGFloat dX=self.bounds.size.width/2, dY=self.bounds.size.height/2;
    self.transform = CGAffineTransformTranslate(CGAffineTransformScale(CGAffineTransformMakeTranslation(-dX, -dY), 1, scaleFactor), dX, dY);
}

- (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view
{
    //Your code goes here

    CGFloat inverseScaleFactor = FIXED_PICKER_HEIGHT/self.frame.size.height;
    CGAffineTransform scale = CGAffineTransformMakeScale(1, inverseScaleFactor);
    view.transform = scale;
    return view;
}
HeikoG
fuente
7

Una manera fácil de cambiar la altura visible de una vista de selector es incrustar el selector en una vista UIView, ajustar la altura de la vista principal a la altura que desea ver del selector y luego habilitar "Subvistas de clip" en Interface Builder en la vista UIView principal o establecido view.clipsToBounds = trueen código.

Subvistas de clips en IB

svarrall
fuente
¿Puedes confirmar que esto realmente funciona? En Xcode parece que aunque se ejecuta en el dispositivo que está mostrando el pickerview más que UIView
nhenrique
1
Funciona @nhenrique, pero no debes olvidar Clip Subviews. también el tamaño del UIPickerViewdebe ser más alto, y debe apuntar el centro de su UIPickerViewpara que sea visible dentro del padreUIView
new2ios
Buena idea, esta fue la solución para mí en iOS 7.1.
Douglas Nassif Roma Junior
Esto no funciona, @ new2ios, ¿puedes confirmar que funciona en iOS8>? Estoy tratando de hacer lo mismo mediante programación.
Hemang
Lo siento, @hagile, pero abandono esa idea, no puedo confirmarlo. Yo uso Storyboard (no se creó a UIPickerViewpartir del código).
new2ios
5

No pude seguir ninguno de los consejos anteriores.

Vi varios tutoriales y encontré este el más beneficioso:

Agregué el siguiente código para establecer la nueva altura dentro del método "viewDidLoad", que funcionó en mi aplicación.

UIPickerView *picker = [[UIPickerView alloc] initWithFrame:CGRectMake(0.0, 0.0, 320.0, 120.0)]; 
[self.view addSubview:picker];
picker.delegate = self;
picker.dataSource = self;

¡Espero que esto haya sido útil!

errar
fuente
4

Esto ha cambiado mucho en iOS 9 (en iOS 8 es bastante similar a lo que estamos viendo aquí). Si puede permitirse apuntar solo a iOS 9, cambie el tamaño delUIPickerView como mejor le parezca, configurando su marco. ¡Bueno!

Aquí está de las notas de la versión de iOS 9

UIPickerView y UIDatePicker ahora son redimensionables y adaptables; anteriormente, estas vistas imponían un tamaño predeterminado incluso si intentaba redimensionarlas. Estas vistas ahora también tienen un ancho predeterminado de 320 puntos en todos los dispositivos, en lugar del ancho del dispositivo en el iPhone.

Las interfaces que se basan en la aplicación anterior del tamaño predeterminado probablemente se verán mal cuando se compilen para iOS 9. Cualquier problema que se encuentre se puede resolver restringiendo completamente o dimensionando las vistas del selector al tamaño deseado en lugar de depender de un comportamiento implícito.

Dan Rosenstark
fuente
2

Estoy trabajando con ios 7, Xcode 5. Pude ajustar la altura del selector de fecha indirectamente encerrándolo en una vista. La altura de las vistas del contenedor se puede ajustar.

servidor
fuente
Esto funcionó siempre y cuando lo ejecuté en ios 7. Cuando ejecuto esta misma compilación en ios 6, el selector completo se muestra para las porciones que se sobrescriben con otras vistas. Siempre que solo apunte a> = 7, esto puede ser viable. Ordenar las vistas de modo que el selector se renderice primero oculta efectivamente las partes periféricas, pero esto solo lo enmascara con otras vistas.
Doug Gerecht
¿Puede explicar un poco más sobre cómo se hizo esto? ¿Es esto solo para reducir la vista o también puede agrandar el selector? Actualmente estoy desarrollando una aplicación para iPad iOS 7 y necesito que el selector sea más alto, pero no importa lo que intente, ¡no puedo hacerlo más grande!
Lizza
2

Cree una vista en IB o código. Agregue su selector como una subvista de esta vista. Cambiar el tamaño de la vista. Esto es más fácil de hacer en IB. Cree restricciones desde la vista a su supervista y desde el selector a esta nueva vista.

Dado que el selector se curva a su alrededor, se extiende por la parte superior e inferior de la vista. Puede ver en IB cuando agrega restricciones superior e inferior desde el selector a la vista, muestra un espacio estándar de algo así como 16 puntos por encima y por debajo del contenedor de supervista. Configure la vista para recortarla si no desea este comportamiento (advertencia fea).

Así es como se ve a 96 puntos de altura en un iPhone 5. El selector con el desbordamiento tiene aproximadamente 130 puntos de altura. ¡Bastante flaco!

Estoy usando esto en mi proyecto para evitar que el selector se extienda a una altura innecesaria. Esta técnica lo recorta y fuerza un derrame más apretado. En realidad, parece más elegante para ser un poco más compacto.

ingrese la descripción de la imagen aquí

Aquí hay una imagen de la vista que muestra el desbordamiento.

ingrese la descripción de la imagen aquí

Aquí están las restricciones de IB que agregué.

ingrese la descripción de la imagen aquí

smileBot
fuente
1

Incluso aunque no esté cambiando el tamaño, otro truco puede ayudar en la situación en la que el UIPicker se encuentra en la parte inferior de la pantalla.

Se puede intentar moverlo ligeramente hacia abajo, pero la fila central debe permanecer visible. Esto ayudará a revelar algo de espacio sobre el selector, ya que las filas inferiores estarán fuera de la pantalla.

Repito que esta no es la forma de cambiar la altura de la vista de UIPicker, sino una idea de lo que puede hacer si todos los demás intentos fallan.

Sergey perdido
fuente
1

Ok, después de luchar durante mucho tiempo con la estúpida vista del selector en iOS 4, he decidido cambiar mi control a una tabla simple: aquí está el código:

ComboBoxView.m = which is actually looks more like pickerview.

//
//  ComboBoxView.m
//  iTrophy
//
//  Created by Gal Blank on 8/18/10.
//

#import "ComboBoxView.h"
#import "AwardsStruct.h"


@implementation ComboBoxView

@synthesize displayedObjects;

#pragma mark -
#pragma mark Initialization

/*
- (id)initWithStyle:(UITableViewStyle)style {
    // Override initWithStyle: if you create the controller programmatically and want to perform customization that is not appropriate for viewDidLoad.
    if ((self = [super initWithStyle:style])) {
    }
    return self;
}
*/


#pragma mark -
#pragma mark View lifecycle

/*
- (void)viewDidLoad {
    [super viewDidLoad];

    // Uncomment the following line to display an Edit button in the navigation bar for this view controller.
    // self.navigationItem.rightBarButtonItem = self.editButtonItem;
}
*/

/*
- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
}
*/
/*
- (void)viewDidAppear:(BOOL)animated {
    [super viewDidAppear:animated];
}
*/
/*
- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];
}
*/
/*
- (void)viewDidDisappear:(BOOL)animated {
    [super viewDidDisappear:animated];
}
*/
/*
// Override to allow orientations other than the default portrait orientation.
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
    // Return YES for supported orientations
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}
*/


#pragma mark -
#pragma mark Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    // Return the number of sections.
    return 1;
}


- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    // Return the number of rows in the section.
    self.tableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine;
    return [[self displayedObjects] count];
}


// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {


    NSString *MyIdentifier = [NSString stringWithFormat:@"MyIdentifier %i", indexPath.row];

    UITableViewCell *cell = (UITableViewCell *)[tableView dequeueReusableCellWithIdentifier:MyIdentifier];

    if (cell == nil) {
        cell = [[[UITableViewCell alloc] initWithFrame:CGRectZero reuseIdentifier:MyIdentifier] autorelease];
        //cell.contentView.frame = CGRectMake(0, 0, 230.0,16);
        UILabel *label = [[[UILabel alloc] initWithFrame:CGRectMake(0, 5, 230.0,19)] autorelease];
        VivatAwardsStruct *vType = [displayedObjects objectAtIndex:indexPath.row];
        NSString *section = [vType awardType]; 
        label.tag = 1;
        label.font = [UIFont systemFontOfSize:17.0];
        label.text = section;
        label.textAlignment = UITextAlignmentCenter;
        label.baselineAdjustment = UIBaselineAdjustmentAlignCenters;
        label.adjustsFontSizeToFitWidth=YES;
        label.textColor = [UIColor blackColor];
        //label.autoresizingMask = UIViewAutoresizingFlexibleHeight;
        [cell.contentView addSubview:label]; 
        //UIImage *image = nil;
        label.backgroundColor = [UIColor whiteColor];
        //image = [awards awardImage];
        //image = [image imageScaledToSize:CGSizeMake(32.0, 32.0)];

        //[cell setAccessoryType:UITableViewCellAccessoryDisclosureIndicator];
        //UIImageView *imageView = [[UIImageView alloc] initWithImage:image];
        //cell.accessoryView = imageView;
        //[imageView release];
    }

    return cell;
}


/*
// Override to support conditional editing of the table view.
- (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath {
    // Return NO if you do not want the specified item to be editable.
    return YES;
}
*/


/*
// Override to support editing the table view.
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath {

    if (editingStyle == UITableViewCellEditingStyleDelete) {
        // Delete the row from the data source
        [tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:YES];
    }   
    else if (editingStyle == UITableViewCellEditingStyleInsert) {
        // Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
    }   
}
*/


/*
// Override to support rearranging the table view.
- (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)fromIndexPath toIndexPath:(NSIndexPath *)toIndexPath {
}
*/


/*
// Override to support conditional rearranging of the table view.
- (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath {
    // Return NO if you do not want the item to be re-orderable.
    return YES;
}
*/


#pragma mark -
#pragma mark Table view delegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
    // Navigation logic may go here. Create and push another view controller.
    /*
     <#DetailViewController#> *detailViewController = [[<#DetailViewController#> alloc] initWithNibName:@"<#Nib name#>" bundle:nil];
     // ...
     // Pass the selected object to the new view controller.
     [self.navigationController pushViewController:detailViewController animated:YES];
     [detailViewController release];
     */
}


#pragma mark -
#pragma mark Memory management

- (void)didReceiveMemoryWarning {
    // Releases the view if it doesn't have a superview.
    [super didReceiveMemoryWarning];

    // Relinquish ownership any cached data, images, etc that aren't in use.
}

- (void)viewDidUnload {
    // Relinquish ownership of anything that can be recreated in viewDidLoad or on demand.
    // For example: self.myOutlet = nil;
}


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


@end

Aquí está el archivo .h para eso:

//
//  ComboBoxView.h
//  iTrophy
//
//  Created by Gal Blank on 8/18/10.
//

#import <UIKit/UIKit.h>


@interface ComboBoxView : UITableViewController {
    NSMutableArray *displayedObjects;
}

@property (nonatomic, retain) NSMutableArray *displayedObjects;


@end

now, in the ViewController where I had Apple UIPickerView I replaced with my own ComboBox view and made it size what ever I wish.

ComboBoxView *mypickerholder = [[ComboBoxView alloc] init]; 
[mypickerholder.view setFrame:CGRectMake(50, 220, 230, 80)];
[mypickerholder setDisplayedObjects:awardTypesArray];

eso es todo, ahora lo único que queda es crear una variable miembro en la vista del cuadro combinado que contendrá la selección de fila actual, y estamos listos para comenzar.

Disfruten a todos.

Alex
fuente
aquí lo que es VivatAwardsStruct, estoy recibiendo un error aquí, VivatAwardsStruct no declarado
Mahesh Babu
1

Por lo general, no puede hacerlo en xib o configurar el marco programáticamente, pero si abre su xib principal como fuente y cambia la altura desde allí, entonces funciona. en esa etiqueta, cambie la altura allí y luego guarde el archivo.

<pickerView contentMode="scaleToFill" id="pai-pm-hjZ">
                                    <rect key="frame" x="0.0" y="41" width="320" height="100"/>
                                    <autoresizingMask key="autoresizingMask" widthSizable="YES" flexibleMaxY="YES"/>
                                    <connections>
                                        <outlet property="dataSource" destination="-1" id="Mo2-zp-Sl4"/>
                                        <outlet property="delegate" destination="-1" id="nfW-lU-tsU"/>
                                    </connections>
                                </pickerView>
iosdev1111
fuente
0

Hasta donde yo sé, es imposible encoger el UIPickerView. Tampoco he visto uno más corto usado en ninguna parte. Supongo que fue una implementación personalizada si lograron reducirla.

NilObject
fuente
Puede cambiar el tamaño de uipickerview horizontalmente, pero si lo establece demasiado corto, provocará fallas visuales.
futureelite7
0

Si desea crear su selector en IB, puede redimensionarlo posteriormente a un tamaño más pequeño. Sin embargo, asegúrese de que todavía se dibuja correctamente, ya que llega un punto en el que se ve atroz.

Rob Winchester
fuente
0

Swift : debe agregar una subvista con clip a límites

    var DateView = UIView(frame: CGRectMake(0, 0, view.frame.width, 100))
    DateView.layer.borderWidth=1
    DateView.clipsToBounds = true

    var myDatepicker = UIDatePicker(frame:CGRectMake(0,-20,view.frame.width,162));
    DateView.addSubview(myDatepicker);
    self.view.addSubview(DateView)

Esto debería agregar un selector de fecha recortado de 100 alturas en la parte superior del controlador de vista.

Miika Pakarinen
fuente
0

Mi truco: use la capa de máscara de datepicker para hacer que datePicker sea visible en alguna parte. como ves, como cambiar el marco del datepicke.

- (void)timeSelect:(UIButton *)timeButton {
UIDatePicker *timePicker = [[UIDatePicker alloc] initWithFrame:CGRectMake(0, 0, kScreenWidth, 550)];
timePicker.backgroundColor = [UIColor whiteColor];
timePicker.layer.mask = [self maskLayerWithDatePicker:timePicker];
timePicker.layer.masksToBounds = YES;
timePicker.datePickerMode = UIDatePickerModeTime;
[self.view addSubview:timePicker];
}

- (CALayer *)maskLayerWithDatePicker:(UIDatePicker *)datePicker {
CAShapeLayer *shapeLayer = [[CAShapeLayer alloc] init];
UIBezierPath *path = [UIBezierPath bezierPathWithRoundedRect:CGRectMake(0, 0, datePicker.width*0.8, datePicker.height*0.8) cornerRadius:10];
shapeLayer.path = path.CGPath;
return shapeLayer;
}
franco
fuente
0

Uso una capa de máscara para cambiar su tamaño de visualización

// swift 3.x
let layer = CALayer()
layer.frame = CGRect(x: 0,y:0, width: displayWidth, height: displayHeight)
layer.backgroundColor = UIColor.red.cgColor
pickerView.layer.mask = layer
John Lee
fuente
0

Incrustar en una vista de pila. La vista de pila es un componente agregado recientemente por Apple en su SDK de iOS para reflejar implementaciones basadas en cuadrículas en bibliotecas frontales basadas en web de scripts java, como bootstrap.

usuario5590043
fuente
0

Como se mencionó anteriormente, UIPickerViewahora es redimensionable. Sin embargo, solo quiero agregar que si desea cambiar la altura de pickerView en una celda de tableView, no tuve ningún éxito al establecer el ancla de altura en una constante. Sin embargo, el uso lessThanOrEqualToConstantparece funcionar.

 class PickerViewCell: UITableViewCell {

    let pickerView = UIPickerView()

    func setup() {

        // call this from however you initialize your cell

        self.contentView.addSubview(self.pickerView)
        self.pickerView.translatesAutoresizingMaskIntoConstraints = false

        let constraints: [NSLayoutConstraint] = [
            // pin the pickerView to the contentView's layoutMarginsGuide

            self.pickerView.leadingAnchor.constraint(equalTo: self.contentView.layoutMarginsGuide.leadingAnchor),
            self.pickerView.topAnchor.constraint(equalTo: self.contentView.layoutMarginsGuide.topAnchor),
            self.pickerView.trailingAnchor.constraint(equalTo: self.contentView.layoutMarginsGuide.trailingAnchor),
            self.pickerView.bottomAnchor.constraint(equalTo: self.contentView.layoutMarginsGuide.bottomAnchor),

            // set the height using lessThanOrEqualToConstant
            self.pickerView.heightAnchor.constraint(lessThanOrEqualToConstant: 100)
        ]

        NSLayoutConstraint.activate(constraints)
     }

 }
MH175
fuente
-1

Después de un largo día de rascarme la cabeza, encontré algo que funciona para mí. Los códigos a continuación volverán a crear el UIDatePicker cada vez que el usuario cambie la orientación del teléfono. Esto eliminará cualquier problema técnico que tenga el UIDatePicker después de un cambio de orientación.

Dado que estamos recreando el UIDatePicker, necesitamos una variable de instancia que mantendrá el valor de fecha seleccionado. Los siguientes códigos se prueban en iOS 4.0.

    @interface AdvanceDateViewController : UIViewController<UIPickerViewDelegate> {
        UIDatePicker *datePicker;
        NSDate *date;
    }


    @property (nonatomic, retain) UIDatePicker *datePicker;
    @property (nonatomic, retain) NSDate *date;

    -(void)resizeViewWithOrientation:(UIInterfaceOrientation) orientation;

    @end

    @implementation AdvanceDateViewController
    @synthesize datePicker, date;

    - (void)viewDidLoad {
      [super viewDidLoad];
          [self resizeViewWithOrientation:self.interfaceOrientation];
    }


    -(void)viewWillAppear:(BOOL)animated{
         [super viewWillAppear:animated];
         [self resizeViewWithOrientation:self.interfaceOrientation];
     }

     - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
         return YES;
     }

     -(void)willRotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation duration:(NSTimeInterval)duration{
      [super willRotateToInterfaceOrientation:toInterfaceOrientation duration:duration];
      [self resizeViewWithOrientation:toInterfaceOrientation];
      }

     -(void)resizeViewWithOrientation:(UIInterfaceOrientation) orientation{
          [self.datePicker removeFromSuperview];
          [self.datePicker removeTarget:self action:@selector(refreshPickupDate) forControlEvents:UIControlEventValueChanged];
          self.datePicker = nil;

          //(Re)initialize the datepicker, thanks to Apple's buggy UIDatePicker implementation
          UIDatePicker *dummyDatePicker = [[UIDatePicker alloc] init];
          self.datePicker = dummyDatePicker;
          [dummyDatePicker release];

          [self.datePicker setDate:self.date animated:YES];
          [self.datePicker addTarget:self action:@selector(refreshPickupDate) forControlEvents:UIControlEventValueChanged];

          if(UIInterfaceOrientationIsLandscape(orientation)){
                 self.datePicker.frame = CGRectMake(0, 118, 480, 162);    
           } else {
                 self.datePicker.frame = CGRectMake(0, 200, 320, 216);
           }

           [self.view addSubview:self.datePicker];
           [self.view setNeedsDisplay];
      }

      @end
chromeragnarok
fuente
-1
stockPicker = [[UIPickerView alloc] init];
stockPicker.frame = CGRectMake(70.0,155, 180,100);

Si desea establecer el tamaño de UiPickerView. El código anterior seguramente funcionará para ti.

Desarrollador
fuente
-1

En iOS 5.0, conseguí que funcionara lo siguiente:

UIDatePicker *picker = [[UIDatePicker alloc] init];
picker.frame = CGRectMake(0.0, 0.0, 320.0, 160.0);

Esto creó un selector de fecha como el que usa Apple en la aplicación Calendario al crear un nuevo evento en modo horizontal. (3 filas de altura en lugar de 5.) Esto no funcionó cuando configuré el marco dentro del initWithFrame:método, pero hasta ahora funciona cuando lo configuré usando un método separado.

Mark Leonard
fuente
-1

para iOS 5:

si echa un vistazo rápido al protocolo UIPickerView Referencia

encontrarás

 pickerView:rowHeightForComponent:
 pickerView:widthForComponent:

Creo que es el primero que estás buscando

Daniel
fuente
pickerView:rowHeightForComponent: es el método delegado para decidir la altura de cada fila, no la altura de la vista del selector.
probado