UIcollectionViewのCustomCellでnil
解決済
回答 1
投稿
- 評価
- クリップ 0
- VIEW 1,979
swift入門者です.
自分で定義したCellをUIcollectionViewで使用したいのですが,うまくいきません.
import UIKit
class ItemListViewController: UIViewController,UICollectionViewDataSource,UICollectionViewDelegate,UICollectionViewDelegateFlowLayout {
@IBOutlet weak var collectionView: UICollectionView!
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
collectionView.backgroundColor = UIColor(red: 238.0/255, green: 238.0/255, blue: 238.0/255, alpha: 238.0/255)
collectionView.registerClass(ItemCell.self, forCellWithReuseIdentifier: "cell")
view.addSubview(collectionView)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// MARK: - UICollectionViewDelegate Protocol
func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
let cell:ItemCell = collectionView.dequeueReusableCellWithReuseIdentifier("cell", forIndexPath: indexPath) as! ItemCell
//title, image, numberともにnilとなってしまい,データをセットできない
cell.title?.text = "いちご"
cell.image?.image = UIImage(named: "pic/ichigo.png")
cell.backgroundColor = UIColor.whiteColor()
cell.number?.text = ""
cell.number?.backgroundColor = UIColor.clearColor()
return cell
}
// Screenサイズに応じたセルサイズを返す
// UICollectionViewDelegateFlowLayoutの設定が必要
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAtIndexPath indexPath: NSIndexPath) -> CGSize {
let space:Int = 5
let stepperSize:Int = 29
let cellSizeWidth:CGFloat = (self.view.frame.size.width - CGFloat(space) * 3) / 2
let cellSizeHeight:CGFloat = cellSizeWidth + CGFloat(stepperSize)
return CGSizeMake(cellSizeWidth, cellSizeHeight)
}
func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
return 1
}
func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 20;
}
}
import UIKit
class ItemCell: UICollectionViewCell {
@IBOutlet weak var title: UILabel!
@IBOutlet weak var image: UIImageView!
@IBOutlet weak var number: UILabel!
//商品の個数をステッパーで変更
@IBAction func changedStepperValue(sender: UIStepper) {
let num = Int(sender.value)
//ラベルに表示
let gray = UIColor.grayColor()
number.backgroundColor = gray.colorWithAlphaComponent(0.6)
number.textColor = UIColor.whiteColor()
number.text = String(num)
//0の時は表示しない
if num == 0 {
number.text = ""
number.backgroundColor = UIColor.clearColor()
}
}
override init(frame: CGRect){
super.init(frame: frame)
}
required init?(coder aDecoder: NSCoder){
super.init(coder: aDecoder)
}
}
ItemListViewController内でcellのデータをセットしたいのですが,
cell.title?.text = "いちご"
の行では,title
が何故かnilのため,
実行しても,真っ白のcellが20個並ぶだけで,LabelやImageが反映されません.
CollectionReusableViewのIdentifierも"cell"と設定してあります.
outlet接続は何度も見なおしたのですが,原因がわからないので質問させていただきました.
よろしくお願いいたします.
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
0
カスタムセルはどうやって定義していますか?
Storyboardでカスタムセルを定義しているのであれば、
collectionView.registerClass(ItemCell.self, forCellWithReuseIdentifier: "cell")
は不要ですので削除してください。
registerClass()
は、カスタムセルをコードで定義する時に使用します。
現在のコードはregisterClass()
を使用しているのにinit(frame: CGRect)
の中で何も部品を作成してないので、titleがnilのままとなります。Storyboardでカスタムセルを定義しているのであれば、registerClass()
を削除することで 自動的にカスタムセルの部品が読み込まれるようになります。
もしカスタムセルをxibファイルで定義しているのであれば、registerClass()
ではなくregisterNib()
を使用して、指定のxibファイルが読み込まれるようにしてください。
(4/25 3:40追記)
ついでに指摘しておくと、おそらく
view.addSubview(collectionView)
も不要だと思います。
collectionViewをStoryboardでビューコントローラーの中に定義しているのであれば、これも自動的にaddSubViewされます。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.35%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
2016/04/25 09:56
ご指摘の通り,カスタムセルをxibで定義していたため,registerNib()を使用した結果,
正常にセルの内容が表示されました.
お手数をお掛けしました.