Как я могу создать меню гамбургера с подменю внутри - PullRequest
0 голосов
/ 25 апреля 2019

Я работаю над приложением, в котором требуется создать меню гамбургера с подменю, например like this

Я пробовал другой метод с использованием таблицы внутри ячейки табличного представления и т. Д., Ноневозможно создать это меню.если у кого-то есть решение, порекомендуйте мне

Ответы [ 4 ]

3 голосов
/ 25 апреля 2019

Вы можете создать такую ​​структуру элемента, как ваш источник данных.

struct Item {
    let text: String
    var subItems: [String]?
    var isExpanded = false
    init(_ text: String, items: [String]? = nil) {
        self.text = text
        self.subItems = items
    }
}

Использование

class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {

    @IBOutlet var tableView: UITableView!

    private let imgOpen = UIImage(named: "open")
    private let imgClose = UIImage(named: "close")

    private var dataSource = [Item]()

    override func viewDidLoad() {
        super.viewDidLoad()

        self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "groupCell")
        self.tableView.dataSource = self
        self.tableView.delegate = self

        self.dataSource.append(Item("HOME"))
        self.dataSource.append(Item("ABOUT US"))
        self.dataSource.append(Item("OUR PROJECTS", items: ["Project-1", "Project-2", "..."]))
        self.dataSource.append(Item("BAHRIA TOWN PHASE 1 - 7"))
        self.dataSource.append(Item("BAHRIA TOWN PHASE 8"))
        self.tableView.reloadData()
    }

    func numberOfSections(in tableView: UITableView) -> Int {
        return self.dataSource.count
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        let item = self.dataSource[section]
        if item.isExpanded, let count = item.subItems?.count {
            return count + 1
        }

        return 1
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            let item = self.dataSource[indexPath.section]

            let cell = tableView.dequeueReusableCell(withIdentifier: "groupCell", for: indexPath)
            var imageView: UIImageView?
            if indexPath.row > 0, let text = item.subItems?[indexPath.row - 1] {
                cell.textLabel?.text = text
            } else {
                cell.textLabel?.text = item.text
                if item.subItems != nil {
                    imageView = UIImageView(image: item.isExpanded ? self.imgClose : self.imgOpen)
                }
            }
            cell.accessoryView = imageView

            return cell
    }

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        let item = self.dataSource[indexPath.section]
        if indexPath.row == 0 && item.subItems != nil {
            self.dataSource[indexPath.section].isExpanded = !item.isExpanded
            let indexSet = IndexSet(integer: indexPath.section)
            tableView.reloadSections(indexSet, with: .automatic)
        } else {
            // non-expandable menu item tapped
        }
    }
}
0 голосов
/ 25 апреля 2019

-> вы можете создать меню скользящего ящика (меню гамбургера), используя любую из следующих библиотек:

1) REFrostedViewController
2) SWRevealViewController or any other

-> Подменю: в контроллере представления ящика необходимо добавить представление таблицы и реализовать раскрывающиеся / складывающиеся секции для отображения подменю. Вы можете следовать любому руководству, объясняющему разделы представления таблицы с развёртыванием и свертыванием. Ниже приведены некоторые ссылки на учебники:

https://github.com/jeantimex/ios-swift-collapsible-table-section
https://medium.com/@legonaftik/uitableview-with-collapsible-sections-927d726b985c
0 голосов
/ 25 апреля 2019

1-й след. https://github.com/jonkykong/SideMenu.

А затем сделать РАСШИРЯЕМЫЕ ячейки : -

Вам просто нужно создать 2 ячейки в UITableView (в раскадровке).Первая ячейка для тех, кто не расширяется, и Вторая ячейка для расширяемых.

class SideMenuTableViewController: UITableViewController {

    // MARK:- Constants And Vars
    var isOurProjectCellExpanded = false
}

class SideMenuTableViewController: UITableViewDataSource, UITableViewDelegate {
      override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            let cell = tableView.dequeueReusableCell(withIdentifier: "simpleCell", for: indexPath) as! SideMenuBasicTableViewCell
            switch indexPath.row {
            case 0:
                cell.itemName.text = "HOME"
                break
            case 1:
                cell.itemName.text = "About Us"
                break
            case 2:
                if(isOurProjectCellExpanded){
                    //expandedCell
                    let cell = tableView.dequeueReusableCell(withIdentifier: "expandedCell", for: indexPath) as! SideMenuBasicTableViewCell
                    cell.itemName.text = "Our Projects"
                    return cell
                }else{
                    cell.arrowDownImageView.isHidden = false
                    cell.itemName.text = "Our Projects"
                }
                break
            case 3:
                cell.itemName.text = "Bahria Town phase 1-7"
                break
            case 4:
                cell.itemName.text = "Bahria Town phase 8"
                break
            default:
                break
            }
            return cell
        }

     //And in `DidSelectRow` Method
     override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
            if(indexPath.row == 2){
                if(isOurProjectCellExpanded){
                    isOurProjectCellExpanded = false
                    tableView.reloadRows(at: [indexPath], with: .none)
                }else{
                    isOurProjectCellExpanded = true
                    tableView.reloadRows(at: [indexPath], with: .none)
                }
            }else if(indexPath.row == 0){
                // Handle it yourself
            }else if(indexPath.row == 1){
                // Handle it yourself
            }else if(indexPath.row == 3){
                // Handle it yourself
            }else if(indexPath.row == 4){
                // Handle it yourself
            }
        }

    }
0 голосов
/ 25 апреля 2019

Вы должны отделить процесс.

  • Сначала создайте меню гамбургера: для этого я рекомендую использовать эту стороннюю библиотеку: https://github.com/John-Lluch/SWRevealViewController С помощью этого очень легко создать боковое меню с левой стороны экрана. Лучше всего, что вы получите ViewController, который будет отвечать за меню, так что вы можете легко настроить его.

  • Во-вторых, как упомянуто ниже, вы должны использовать tableView с расширяемыми ячейками. Лучший способ сделать это - просто показать заголовки ячеек. Если пользователь нажимает на заголовок, то показывает фактическую ячейку. (высота строки> 0). Об этом есть учебное пособие: https://www.youtube.com/watch?v=bSKUYRsMCrM

...