![]() |
Здравствуйте, гость ( Вход | Регистрация )
![]() |
![]() ![]()
Сообщение
#1
|
|||||||||||||||||
Level 10 ![]() ![]() ![]() Класс: Воин Характер: Lawful Neutral Раса: Человек NWN: Скриптинг [PW] ![]() |
На что способна эта система крафта – одному автору известно. И потому было решено начать ликбез по CNR. А начать я бы его хотел с ответа на вопрос Balrog’а – Как написать свой рецепт?! Мало того, мы еще затронем то – как написать рецепт при этом внеся новый типа материала для крафтинга и дележку крафтовых вещей по типу. А все начиналось с тулсета и модуля CNR… Задача урока – Создать раздел спец оружия. Создать подраздел клинков. Написать рецепт на клинок. Открываем модуль CNR в тулсете. Так… Ищем скрипт наковальни. Он называется «cnrAnvilPublic». А вот теперь уже начинаем творить! Создадим новый раздел в наковальне – «Специальное оружие». Для этого найдем строчки:
Добавим ниже строку:
Ниже идут строки:
Добавим сюда наш пункт:
Прокручиваем скрипт ниже… Эта команда подсчитывает рецепты. Смотрим:
Добавляем:
Так дальше идет уже дележка на типы и рецепты. Крутим в самый низ, там где заканчивается строчками:
И начинаем монстрячить свой раздел:
Ну и кончено, с шансом 65% у меня сделать свой меч получилось ;) Результат показан на рис.6 и 7. Картинка результатов: (IMG:http://saigh.nm.ru/text/images/CNR1.jpg) Если не видно - жми сюда Думаю все должно быть понятно. Удачи вам!:) Спрашивайте если что. Сообщение отредактировал Аваддон - Nov 15 2004, 20:13 |
||||||||||||||||
![]() |
![]()
Сообщение
#2
|
|
Level 3 ![]() Класс: Обыватель Характер: Lawful Good Раса: Человек ![]() |
Молодец Аваддон, мы все очень рады, что работаем вместе с тобой, и друг другом. :good:
|
![]()
Сообщение
#3
|
|
Великий хранитель фотоальбома ![]() Класс: Оборотень Характер: Chaotic Neutral Раса: Тварь МАСТЕР Кисти ![]() |
:D :D Джон сказал "все ооооооочень рады" ... да и многие увидев твой ликбез обрадуются :yes: :good:
|
![]() ![]()
Сообщение
#4
|
|||||||||
Level 10 ![]() ![]() ![]() Класс: Воин Характер: Lawful Neutral Раса: Человек NWN: Скриптинг [PW] ![]() |
Итак, для начала в дебри лезть не буду. Возьму первое главное - это конфиг. Открываем скрипт cnr_config_ing. Там можно найти много разных приблуд по настройке CNR. :swoon: :D Что я изменил чтобы уменьшить лаги: 1. Этот пункт влияет на инициализацию рецептов. Если TRUE то CNR инициализирует все рецепты при первой загрузке модуля, естественно мод грузится будет долго. Если FALSE то будет инициализировать определенную часть рецептов при первичном использовании крафт инструмента. Если у вас шард, то лучше ставить TRUE. По крайней мере во время игры лагов у игроков не будет.
2. По слухам CNR еще лагает когда игроки смотрят список 10 лучших мастеров. Отключаем его. То есть прячем список.
3. Если вы не хотите чтобы CNR показывал какие компоненты нужны игроку чтобы что-либо скрафтить, ставите TRUE. Но при этом увеличивается нагрузка на отсев рецептов , следовательно лаги. Ставим FALSE.
4. Появляется нагрузка на отсев рецептов аналогично п.3. А сама функция если TRUE - прячет рецепты до которых игрок еще не дорос. Ставлю FALSE.
Вроде бы пока что все. Признаюсь, лаги немножко уменьшились. Гы. Жду ваших советов. Может еще поможете как его на MySQL перевести? А то я в этом не варю не фига. :drag: |
||||||||
![]() ![]()
Сообщение
#5
|
|||||||||||||||||||||||||
Level 10 ![]() ![]() ![]() Класс: Воин Характер: Lawful Neutral Раса: Человек NWN: Скриптинг [PW] ![]() |
Продолжу свою тему :dirol: Я думаю если так дальше пойдет можно будет книжки издавать хе хе... ВНИМАНИЕ! Данный урок не представляет из себя пособия по NWNX2 итп. Он так же не расчитан на опытных мастеров. Урок предназначен для людей впервые столкнувшихся с MySQL+NWNX2 (таких как я). Здесь я делюсь опытом (грабли собираю сам :yes: ) полученным мною в процессе своей работы с CNR 3.05, дабы людям было проще разобраться. :this: Ликбез по CNR - УРОК №3: :buba: Тема сегодняшнего урока: - Как перевести CNR 3.05 с DataBase Bioware на MySQL? Цели сегодняшнего урока: - Получить первичные навыки работы с MySQL - Получить первичные навыки работы с APS/NWNX 2 - Уменьшить количество лагов в CNR за счет перведения оного на MySQL Необходимый софт: - MySQL - MyODBC: Драйвер odbc для MySQL - APS/NWNX 2 - PHP My Admin или SQLyog Примечание: Сразу скажу - данное действо происходило на OS: Windows XP (Professional Edition) и в качестве софта был установлен пакет Apache+PHP+MySQL. Часть 1 - МуСКУЛ
Если у вас есть MySQL это хорошо. Если его нет - отправляйтесь по ссылке и качайте. У меня уже был MySQL версии 4.0.16-nt, поэтому я данной процедуре время не уделял. Установка тоже довольно таки простая - это сделать будет легко и без моей помощи. А вот теперь начинается самое интересное. После того как мы установили MySQL нам надо настроить его связь с ODBC.
Сейчас нам надо бы зайти в Панель Управления -> Администрирование -> Источники Данных (ODBC) -> Системный DSN -> Добавить... , НО (!) там нет типа базы данных MySQL есть только SQL сервер, а это нам не подходит. Да еще к тому же MySQL пишет : My ODBC Driver Not Found.... В таком случае еще раз отправляемся по ссылке и скачаиваем MyODBC: Драйвер odbc для MySQL. Распаковывайте скачанный архивчик и запускайте setup. Устанавливается легко и безболезненно. В итоге у нас появится драйвер MySQL в Системном DSN. Так, все установили? Опять идем в Панель Управления -> Администрирование -> Источники Данных (ODBC) -> Системный DSN -> Добавить... Вуаля! У нас появился драйвер MySQL (IMG:http://saigh.fatal.ru/text/images/cnr_3_2.gif) Выбираем этот драйвер и появляется окно настроек: (IMG:http://saigh.fatal.ru/text/images/cnr_3_3.gif) Потом нажимаем ОК и получаем:
Жмем везде OK и закрываем окна. Часть 2я - APS/NWNX 2 и Создаем базу данных "nwn" в MySQL при помощи PHP My Admin Скачиваем APS/NWNX 2 по ссылке на nwvailt'е. Распаковываем архив. Файлы: NWNX2.exe, madCodeHookLib.dll, nwnx-module.dll, nwnx_odbc.dll(находится в папке "modules") копируем в директорию с NWN'ом (это там где у нас находится nwmain.exe и nwserver.exe). Все, на это с APS/NWNX 2 пока что закончили - мы это "установили". Устанавливаем Php My Admin и создаем с помощью него базу данных nwn. Действия должны быть такими: (IMG:http://saigh.fatal.ru/text/images/cnr_3_4.gif) Часть 3я - "Заставляем модуль работать с тем, что мы сотворили" или "Не все скрипты одинаково полезны" Откроем модуль CNR 3.05 RUS в редакторе Aurora Toolset. Сейчас предстоят глобальные изменения: Шаг 1. В скрипте cnr_config_inc меняем переменную CNR_BOOL_RECIPE_DATA_IS_PERSISTENT_IN_SQL_DATABASE с FALSE на TRUE
Шаг 2. Откройте скрипт cnr_persist_inc и ЗАкоментируйте строчки для Bioware DataBase и РАСкоментируйте строчки для APS. ПРИМЕР(!это только пример - там их больше!!)
Шаг 3. Проверьте скрипт cnr_module_oml. Там должны быть закоментированы строчки для MS Access и раскоментированы для MySQL. Если это так - то все нормально. Если нет - раскоментируйте строчки "dor MySQL" Шаг 4. Если вы действительно глянули в скрипт cnr_module_oml, то должны были увидеть с самого начала функцию:
. Хм...хм... Если вы посмотрите в списке скриптов модуля, то не найдете этого самого скрипта aps_onload. Видимо автор так устал, что совсем забыл его добавить в модуль. Чтож, вам придется самим создать скрипт с именем aps_onload и содержанием:
Слава богу, инклюд aps_include в модуле присутствует. Если нет то оба скрипта можно взять в erf архиве который поставляется вместе с NWNX 2. Все сделали? Теперь сохраняем модуль, и с полной ответственностью жмем Build Module. Ошибок нет? Тогда еще разок сохраняем. Шаг 5. Запускаем тот NWNX2.exe который мы с остальными файлами скопировали в директорию с NWN. У вас должно открыться окошко NWNX2 и буквально следом автоматическии окошко сервера. Запускаете наш модуль. Как только он загрузится (в состоянии будет написано Running, login at will) выключаете сначала NWNX2, затем NWSERVER.EXE. Не спрашивайте зачем - так нужно. Теперь откройте с помощью Php My Admin базу данных "nwn". Там раньше было "nwn (-)", а теперь "nwn (5)". Сервер при загрузке модуля созда 5(!) таблиц:
Щелкните на cnr_misc и прокрутите окно немного вниз. Там должно быть окошко: Выполнить SQL запрос(ы) на БД И у меня(!) там по умолчанию написано: SELECT * FROM `cnr_misc` WHERE 1. Сотрите это, и напишите строчку:
Где MODULE - это ТЭГ модуля. Затем нажмите Go(Пошел) ну или как у вас там будет:). Запрос в SQL должен выполнится без ошибок и в таблице cnr_misc появится строчка:
Закрываем базу данных и еще раз запускаем NWNX2 и загружаем модуль. Чувствуете? Теперь он грузится чуть дольше чем в первый раз - это записываются рецепты в базу данных "nwn". Шаг 6. Дополнение Как утверждает автор - вы можете перезагружать рецепты "on-the-fly". Для этого следует перезарузить крафтоый аппарат к которыму добавленные рецепты относятся. Крафтовые аппараты перезагружаются при помощи SQL запроса в базу даных "nwn". Шаблон SQL запроса:
Где XXX - это аппарат. В пример он приводит Наковальню для доспехов
И после того запроса, когда игрок будет использоваться Наковальню для доспехов - рецепты для нее будут перезагружены. В заключении... Можете зайти и проверить количество рецептов CNR выдает игроку при входе(их должно быть 1214 чтоль по умолчанию). Зайдите в базы данных. Теперь вы можете просмотреть остальные 4 таблицы, которые до этого момента просмотреть было нельзя. :yahoo: Все. Теперь, когда рецепты загружены, при каждома запуске модуля сервер будет считывать их их нашей базы данных на MySQL. P.S. ВНИМАНИЕ!!! :buba: С этого момента модуль запускать только при помощи NWNX! В противном случае данные измененные в течении игры (рецепты, опыт, скиллы) в базу данных записаны не будут. Урок №3 объявляю завершенным :sleep: И пока прощаюсь с вами до новых постов и (надеюсь) последующих уроков... ® Avaddon 15.11.2004 Сообщение отредактировал Аваддон - Nov 19 2004, 21:31 |
||||||||||||||||||||||||
![]()
Сообщение
#6
|
|
Level 1 Класс: Страж Тьмы Характер: True Neutral Раса: Элементаль ![]() |
Вопрос :
ТЫ пишишь MySQL это одно и тоже , что и Microsoft SQL Server 2000 или SQLEXPR ?! :unsure: |
![]()
Сообщение
#7
|
|
Level 10 ![]() ![]() ![]() Класс: Воин Характер: Lawful Neutral Раса: Человек NWN: Скриптинг [PW] ![]() |
Наверное все же нет. Ибо тогда не было отдельных сайтов по MySQL и собственно сайта разработчиков этой СУБД. Я вроде пояснял что SQL Server нам не подходит.
|
![]()
Сообщение
#8
|
|||||
Level 10 ![]() ![]() ![]() Класс: Воин Характер: Lawful Neutral Раса: Человек NWN: Скриптинг [PW] ![]() |
Ага! Вот и нашел свой первый недочет! Граждане, если кто промучался и выполнил все что я написал и все равно что то да неработает - я сейчас объясню в чем "фишка". У человека одного который эту систему интегрировал возникла проблема. У него есть модуль он интегрировал туда систему, потом выполнил SQL запрос и заново загрузил модуль, но рецепты не прочитались. Сейчас объясню почему. Посмотрев его базу данных в SQL я заметил что под графой "tag" в таблице cnr_misc у него вместо MODULE написано было совсем другое - что при ближайшем рассмотрении оказалось тэгом модуля. Так что учтите в
- MODULE это тэг модуля! Он может быть любым какой вы зададите в свойствах модуля. Следовательно запрос должен быть таким
|
||||
![]()
Сообщение
#9
|
|
Level 2 ![]() Класс: Маг Характер: Lawful Evil Раса: Полуэльф ![]() |
Апну старую тему (:
Поставил себе mysql, nwnx2, cnr. И такая проблема: в базу рецепты и т.п. на русском пишет нормально, а при чтении из базы выводятся вопросы вместо русских букв. Не знаете в чем может быть проблема? Сообщение отредактировал Life - Aug 14 2010, 14:00 |
![]()
Сообщение
#10
|
|
Level 5 ![]() Класс: Обыватель Характер: Lawful Neutral Раса: Человек NWN: Модмейкер Проклятие Левора Порядок Времени ![]() |
база в какой кодировке?
|
![]()
Сообщение
#11
|
|
Level 2 ![]() Класс: Маг Характер: Lawful Evil Раса: Полуэльф ![]() |
система winXP
в базе cp1251 CODE +--------------------------+----------------------------------+ | Variable_name | Value | +--------------------------+----------------------------------+ | character_set_client | cp1251 | | character_set_connection | cp1251 | | character_set_database | cp1251 | | character_set_filesystem | binary | | character_set_results | cp1251 | | character_set_server | cp1251 | | character_set_system | utf8 | п.с. проблема решилась установкой в настройках ODBC драйвера кодировки cp1251. Сообщение отредактировал Life - Aug 14 2010, 11:16 |
![]() ![]() |
Текстовая версия | Сейчас: 29th April 2025 - 22:47 |