Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/20: Рейтинг темы: голосов - 20, средняя оценка - 4.65
6 / 6 / 0
Регистрация: 17.10.2011
Сообщений: 153

Архитектура приложения IRC-клиент для Android

03.09.2012, 21:28. Показов 3960. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
Я решил написать в первый раз в своей жизни приложения для android – irc клиент.
Опыта написания под эту платформу у меня нет, да и вообще никогда ничего крупного я не разрабатывал. В связи с этим, у меня возникли проблемы с архитектурой приложения.
Прочитав статью, я понял, что в приложениях под андроид используется паттерн mvvm. В качестве видов используются layout-ы, в качестве ViewModel используются наследники класса Activity, а в качестве моделей – наследники классов ContentProvider и Service.
Немного поразмыслив, я пришёл к тому, что в приложение будут следующие layout: главное окно, окно настроек (там будут конкретные пункты настроек, например, основные настройки, настройки текста и т.д.), окно каналов (вероятно, все каналы и приватные разговоры будут реализованы в одном окне с помощью tab).
Как я понимаю, под каждый из этих layout нужно создать ViewModel и модель?
С другой стороны, подумав, я понял, что мне нужны, как минимум, следующие классы для полноценной работы приложения:
1) Класс Irc, который будет реализовывать основные операции: коннект на сервер, отправка сообщения, прием сообщения, авторизация и т.д. Кстати, вроде бы все операции с сетью нужно выносить в отдельный поток?
2) Класс StringParser, который отвечает за парсинг строк, полученных от сервера или клиента. Класс определяет, что нужно сделать. Например, если пришла команда от сервера 450 – показать человеку список, или, например, если человек написал в чат /msg NICKNAME msg, то нужно открыть окно личной беседы NICKNAME и отправить msg. На вход главного метода в этом классе поступает строка, а на выходе ожидается действие, которое нужно где-то совершить, и какой-то массив информации.
Не очень понятно, как представить эту информацию (действие и информацию). Можно, конечно же, просто создать какой-нибудь массив, но это вроде бы не лучший вариант.
3) Класс Сommands, который, наверное, должен запустить новый поток (класс Irc), который будет работать с сетью. Далее этот класс, наверное, будет получать данные от клиента и сервера, отправлять их классу StringParser и вызывать те команды, которые нужно.
4) Вроде бы нужны классы, которые будут реализовывать такие действия, как редактирование настроек, отображение списка ников и т.д. Однако я думаю, что все эти классы – это типичные представители Модели в паттерне MVVM.

Итак, это было предисловие. Что вам не нравится в том, что я сказал? Как исправить, что делать?
Вопросы:
1) Как пристроить классы Irc, StringParser, Commands в паттерн MVVP?
2) Если классы Irc, StringParser, Commands – это хелперы, то какой жизненный цикл приложения? Человек заходит в программу, грузится основное окно, и, я думаю, создается объект класса Commands. Он, в свою очередь, создает объект класса Irc, который должен работать в новом потоке. Что дальше? Все действия пользователя в моделях перенаправлять на объект класса Commands?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.09.2012, 21:28
Ответы с готовыми решениями:

Архитектура клиент серверного приложения
Добрый день. Возникла идея проекта, но как реализовать его я не представляю. Есть клиентское андроид приложение, в котором присутствует...

Архитектура клиент-серверного приложения с off-line режимом
Доброго дня. Столкнулся со следующим вопросом на тестировании: Создаётся Android-приложение, работающее с данными на сервере. В...

Правильная архитектура Android приложения, использующего restful api
Добрый день! есть задача написать приложение. Главный функционал- отображение данных из БД. БД должна обновляться через указанный...

5
146 / 129 / 6
Регистрация: 29.07.2008
Сообщений: 506
03.09.2012, 21:40
если есть опыт программирования на java:
почитайте про GOF паттерны + книжка Голощапова по программированию на андройде. - это порог входа.
после этого потренируйтесь писать приложения работающие с сетью, а потом уже беритесь за свой проект.
1
6 / 6 / 0
Регистрация: 17.10.2011
Сообщений: 153
03.09.2012, 21:46  [ТС]
Цитата Сообщение от YAUHEN Посмотреть сообщение
если есть опыт программирования на java:
почитайте про GOF паттерны + книжка Голощапова по программированию на андройде. - это порог входа.
после этого потренируйтесь писать приложения работающие с сетью, а потом уже беритесь за свой проект.
Опыта на JAVA нет, но я немного писал на c#.
Спасибо за совет, посмотрю, что это за книга.
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
03.09.2012, 21:48
Цитата Сообщение от Hixon10 Посмотреть сообщение
Как я понимаю, под каждый из этих layout нужно создать ViewModel и модель?
да, каждое окно - это активити.
а вот моделей может и вовсе не быть, особенно если иметь ввиду только ContentProvider и Service. хотя модель, это более общее понятие.

Цитата Сообщение от Hixon10 Посмотреть сообщение
все операции с сетью нужно выносить в отдельный поток?
да.


Цитата Сообщение от Hixon10 Посмотреть сообщение
Вроде бы нужны классы, которые будут реализовывать такие действия, как редактирование настроек, отображение списка ников и т.д. Однако я думаю, что все эти классы – это типичные представители Модели в паттерне MVVM.
PreferenceActivity, ListActivity и т.д. и это не модели, а ViewModel.


Цитата Сообщение от Hixon10 Посмотреть сообщение
Все действия пользователя в моделях перенаправлять на объект класса Commands?
BroadcastReceiver
1
Android Programmer
141 / 142 / 10
Регистрация: 08.12.2010
Сообщений: 421
05.09.2012, 21:16
Цитата Сообщение от V0v1k Посмотреть сообщение
BroadcastReceiver
надеюсь это была неудачная шутка?
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
05.09.2012, 22:36
нет, он предназначен именно для обработки событий
Цитата Сообщение от Hixon10 Посмотреть сообщение
Например, если пришла команда от сервера 450 – показать человеку список, или, например, если человек написал в чат /msg NICKNAME msg, то нужно открыть окно личной беседы NICKNAME и отправить msg.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.09.2012, 22:36
Помогаю со студенческими работами здесь

Архитектура клиент-серверного приложения для многопользовательской работы через интернет в real-time режиме
Приветствую уважаемое сообщество. Нужно срочно собрать мысли по следующей теме. Необходимо создать работающий прототип некого...

Архитектура клиент-серверного приложения
Доброго времени суток. Стоит задача - разработать 4 не больших приложения, из них 3 клиента и 1 сервер. Задача сервера: 1. слушать...

Архитектура сервера клиент-серверного приложения
Подскажите пожалуйста какие-то готовые архитектурные решения для организации серверной части такой системы: сервер парсит сайт, сохрпняет...

Архитектура приложения клиент, прошу совета
Ситуация - есть некий программный сервер с БД и текущими состояниями массива объектов. Приложение цепляется к нему по WCF. Приложение...

Архитектура и проектирование клиент-серверного приложения на основе nodejs
Здравствуйте. Я в данный момент занимаюсь изучением JS и, честно, ещё не добрался до работы с Node и его библиотеками. Возможно,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 17.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 14.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru