UI控件(UIPickerView)

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];

    _item1 = [[NSArray alloc]initWithObjects:@"大类1",@"大类2", nil];
    _item2 = [NSDictionary dictionaryWithObjectsAndKeys:@[@"子类11",@"子类12"],@"大类1",@[@"子类21",@"子类22"],@"大类2",nil];
    _item3 = [NSDictionary dictionaryWithObjectsAndKeys:@[@"条目111",@"条目112"],@"子类11",@[@"条目121",@"条目122"], @"子类12",nil];

    _pickview = [[UIPickerView alloc]init];
    _pickview.dataSource = self;
    _pickview.delegate = self;

    _pickview.frame = CGRectMake(0, 10, 300, 100);
    _pickview.showsSelectionIndicator = YES;

    [self.view addSubview:_pickview];

}

// UIPickerViewDataSource协议必须实现的方法
// 确认该控件有多少列
- (NSInteger)numberOfComponentsInPickerView:(UIPickerView*)pickerView
{
    return 3;
}

//UIPickerViewDataSource协议必须实现的方法
//返回当前列显示的行数
-(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component{
    if(0 == component){
        return _item1.count;
    }else if(1 == component){
        NSInteger item1 = [_pickview selectedRowInComponent:0];
        NSString  *item1Name = _item1[item1];
        NSArray *array = [_item2 valueForKey:item1Name];

        return array.count;
    }else if(2 == component){
        NSInteger item1 = [_pickview selectedRowInComponent:0];
        NSString  *item1Name = _item1[item1];
        NSArray *array = _item2[item1Name];
        NSInteger item2 = [_pickview selectedRowInComponent:1];
        NSString  *item2Name = array[item2];
        NSArray *array2 = _item3[item2Name];
        return array2.count;
    }else{
        return 0;
    }
}

//UIPickerViewDelegate协议要求实现
//返回当前行的内容,此处是将数组中数值添加到滚动的那个显示栏上
-(NSString*)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component
{
    if(0 == component){
        return _item1[row];
    }else if(1 == component){
        NSInteger item1 = [_pickview selectedRowInComponent:0];
        NSString  *item1Name = _item1[item1];
        NSArray *array = _item2[item1Name];
        return array[row];
    }else if(2 == component){
        NSInteger item1 = [_pickview selectedRowInComponent:0];
        NSString  *item1Name = _item1[item1];
        NSArray *array = _item2[item1Name];
        NSInteger item2 = [_pickview selectedRowInComponent:1];
        NSString  *item2Name = array[item2];
        NSArray *array2 = _item3[item2Name];
        return array2[row];
    }else{
        return NULL;
    }
}

//获取选择的数据
//监听轮子的移动
- (void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component{
    if(0 == component){
        //重新加载第二列的数据
        NSLog(@"%@", _item1[row]);
        [_pickview reloadComponent:1];
    }else if(1 == component){
        //重新加载第三列的数据
        [_pickview reloadComponent:2];
        NSInteger item1 = [_pickview selectedRowInComponent:0];
        NSString  *item1Name = _item1[item1];
        NSArray *array = _item2[item1Name];
        NSLog(@"%@", array[row]);
    }else if(2 == component){
        NSInteger item1 = [_pickview selectedRowInComponent:0];
        NSString  *item1Name = _item1[item1];
        NSArray *array = _item2[item1Name];
        NSInteger item2 = [_pickview selectedRowInComponent:1];
        NSString  *item2Name = array[item2];
        NSArray *array2 = _item3[item2Name];
        NSLog(@"%@", array2[row]);
    }
}

//工具函数,遍历字典
-(void)describeDictionary:(NSDictionary *)dict
{
    NSArray *keys;
    int i, count;
    id key, value;

    keys = [dict allKeys];
    count = [keys count];
    for (i = 0; i < count; i++)
    {
        key = [keys objectAtIndex: i];
        value = [dict objectForKey: key];
        NSLog (@"Key: %@ for value: %@", key, value);
    }
}

@end
时间: 2024-10-12 05:47:58

UI控件(UIPickerView)的相关文章

【IOS 开发】基本 UI 控件详解 (UIDatePicker | UIPickerView | UIStepper | UIWebView | UIToolBar )

转载注明出处 : http://blog.csdn.net/shulianghan/article/details/50348982 一. 日期选择器 (UIDatePicker) UIDatePicker 属性截图 : 1. UIDatePicker 控件属性 (1) Mode 属性 Mode 属性 : 用于设置 UIDatePicker 模式; -- Date 属性值 : 显示日期, 不显示时间; -- Time 属性值 : 显示时间, 不显示日期; -- Date and Time 属性值

swift常用UI控件的使用方法

对于习惯了OC代码的程序员来说,swift的语法简直让人不能忍受,今天将一些常用的UI控件简单做了一下整理. import UIKit class ViewController : UIViewController, UIPickerViewDataSource, UIPickerViewDelegate { override func viewDidLoad() { super.viewDidLoad() self.view.backgroundColor = UIColor.whiteCol

android_常用UI控件_01_TextView3_点击打开新的activity

点击textview打开新的activity (1) MainActivity.java package com.example.android_textview_opennewactivity; import android.os.Bundle; import android.app.Activity; import android.content.Intent; import android.text.SpannableString; import android.text.Spanned;

android_常用UI控件_01_TextView4_rollingsubtitles效果加链接文字

(1)Mainactivity.java package com.example.android_textview_rollingsubtitles; import java.sql.Wrapper; import android.os.Bundle; import android.app.Activity; import android.text.Html; import android.text.TextUtils; import android.text.TextUtils.Truncat

C# WPF 使用委托修改UI控件

近段时间在自学WPF,是一个完全不懂WPF的菜鸟,对于在线程中修改UI控件使用委托做一个记录,给自已以后查询也给需要的参考: 界面只放一个RichTextBox,在窗体启动时开起两个线程,调用两个函数,每隔1秒写一次当前时间 一 界面XAML如下: <Window x:Class="WpfApplication1.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation&qu

UI控件

在iOSAPP中,能在屏幕上显示的按钮.文本标签.文字输入框等等,都是UI控件. UIview: 苹果把所有UI控件的共同属性抽出来放在UIView中,即所有UI控件都是UIView的子类(不一定是直接子类). 注意:UIView继承自UIresponder,可以响应用户的操作. UIView的重要属性 frame:View的位置和宽高 bounce:相对于自己的左上角的位置和宽高 center:中心点的坐标 backgroundcolor:背景颜色 UIView的常用方法:UIView既可以显

Atitit.swt&#160;线程调用ui控件的方法

Atitit.swt 线程调用ui控件的方法 1 SwingUtilities.invokeLater1 2 display.asyncExec方法1 3  display.timerExec(500,timer);2 4 .但有时候并不一定要程序执行时就要定时检测,有时需要外部事情激发这就出现了第2种解决方案,写一个内置类,可以放在事件监听的方法中,然后激发:2 5 参考3 1   SwingUtilities.invokeLater SwingUtilities.invokeLater(ne

iOS UI控件没有显示时的调试技巧

1.遇到UI控件没有显示的问题,可以给这个控件设置背景色 假设这个控件是UIBUtton 如果背景色能显示,那问题就出在image和title值为空 如果背景色不能显示,重写控件的description方法,把控件的frame打印出来分析 2.以下是打印UIView的frame的分类 #import <UIKit/UIKit.h> @interface UIView (Log) @end 1 #import "UIView+Log.h" 2 3 @implementatio

JavaFX - UI控件 - 标签

  2标签(Label) 本章主要介绍如何使用标签(Label),该类位于JavaFX API的javafx.scene.control包中,用于显示一个文本元素. 接下来会介绍如何让文本元素自动换行来适应受限空间,添加一个图标,或使用视觉特效. 图2 - 1显示了标签的三种常见用法. 左边的标签是一个带图标的文本,中间的展示了旋转效果,右边的使用了自动换行设置. 图2 - 1 标签示例 这幅图显示了三个标签,他们被放在了同一行. 左边的标签有一个看起来像个放大镜的图标和一个"Searc

根据ui控件的字体计算占用的长度

//1.根据icon计算name的长度 CGFloat nameX = CGRectGetMaxX(_icon.frame) + kBorder; CGFloat nameY = iconY; //计算用户昵称的长度 CGSize nameSize = [_weiBo.name sizeWithFont:_name.font]; _name.frame = CGRectMake(nameX, nameY, nameSize.width, nameSize.height); //2.设置vip的f