-
Total de itens
1347 -
Registro em
-
Última visita
-
Dias Ganhos
36
Tudo que Oneshot postou
-
Pior é pagar um valor exorbitante por um domínio, pesquisa o TOP 10 no Google.
-
Manual de Referência de Lua 5.1 - índice CTRL+C e CTRL+V Por favor, né, cara?
-
local TRANSFORMATIONS = { -- NARUTO [69] = {outfit = {lookType = 64}, useEffect = 10, pEffect = 18}, [64] = {outfit = {lookType = 31}, useEffect = 24, pEffect = 12}, [31] = {outfit = {lookType = 90}, useEffect = 24, pEffect = 15}, [90] = {outfit = {lookType = 89}, useEffect = 24, pEffect = 11}, -- SASUKE [5] = {outfit = {lookType = 6}, useEffect = 25, pEffect = 9}, [6] = {outfit = {lookType = 7}, useEffect = 23, pEffect = 14}, [7] = {outfit = {lookType = 8}, useEffect = 14, pEffect = 14}, -- SAKURA [9] = {outfit = {lookType = 10}, useEffect = 2, pEffect = 19}, [10] = {outfit = {lookType = 11}, useEffect = 50, pEffect = 19}, [11] = {outfit = {lookType = 12}, useEffect = 33, pEffect = 14}, } local function delayed_magic_effect(cid) if not isCreature(cid) then return true end local outfit = getCreatureOutfit(cid) local tmp = TRANSFORMATIONS[outfit.lookType] if not tmp then return true end doSendMagicEffect(getCreaturePosition(cid), tmp.pEffect) return addEvent(function() delayed_magic_effect(cid) end, 1000) end function onSay(cid, words, param) local outfit = getCreatureOutfit(cid) local tmp = TRANSFORMATIONS[outfit.lookType] if not tmp then return doPlayerSendCancel(cid, "Você não possui transformações.") end local storage = outfit.lookType + 25000 if getCreatureStorage(cid, storage) == 2103 then return doPlayerSendCancel(cid, "Você ainda não completou a quest necessária para usar essa transformação.") end doSendMagicEffect(getCreaturePosition(cid), tmp.useEffect) doSetCreatureOutfit(cid, tmp.outfit, -1) delayed_magic_effect(cid) return true end Dessa vez testei. Tchau, não volto aqui mais.
-
Editei o script acima, errei na ordem do escopo. Acho que pode funcionar agora, sem erros.
-
dúvida Como eu posso fazer direito essa formula?
pergunta respondeu ao Tony Araujo de Oneshot em Resolvidos
uint16_t Monsters::getLootRandom() { return (uint16_t)std::ceil((double)random_range(0, MAX_LOOTCHANCE) / g_config.getDouble(ConfigManager::RATE_LOOT)); } Você inseriu isso: player->getDurability(); Aí eu te pergunto: Onde você declarou o objeto player nessa função, para usar o método getDurability() nele? Tchau. -
COLOR_BLACK = 0 COLOR_BLUE = 5 COLOR_GREEN = 18 COLOR_TEAL = 35 COLOR_LIGHTGREEN = 66 COLOR_DARKBROWN = 78 COLOR_LIGHTBLUE = 89 COLOR_MAYABLUE = 95 COLOR_DARKRED = 108 COLOR_DARKPURPLE = 112 COLOR_BROWN = 120 COLOR_GREY = 129 COLOR_DARKPINK = 152 COLOR_PURPLE = 154 COLOR_DARKORANGE = 156 COLOR_RED = 180 COLOR_PINK = 190 COLOR_ORANGE = 192 COLOR_DARKYELLOW = 205 COLOR_YELLOW = 210 COLOR_WHITE = 215 COLOR_NONE = 255 São 215 cores, essas são as que tem nome declarado. Seu segundo pedido, sobre explicar cada function do Open Tibia, é meio inviável, eu aprendi a usar cada uma e o que seus parâmetros retornavam, printando cada um e posteriormente nas sources. Abraços.
-
Vê aí se funciona, não testei. local TRANSFORMATIONS = { -- NARUTO [69] = {outfit = {lookType = 64}, useEffect = 10, pEffect = 18}, [64] = {outfit = {lookType = 31}, useEffect = 24, pEffect = 12}, [31] = {outfit = {lookType = 90}, useEffect = 24, pEffect = 15}, [90] = {outfit = {lookType = 89}, useEffect = 24, pEffect = 11}, -- SASUKE [5] = {outfit = {lookType = 6}, useEffect = 25, pEffect = 9}, [6] = {outfit = {lookType = 7}, useEffect = 23, pEffect = 14}, [7] = {outfit = {lookType = 8}, useEffect = 14, pEffect = 14}, -- SAKURA [9] = {outfit = {lookType = 10}, useEffect = 2, pEffect = 19}, [10] = {outfit = {lookType = 11}, useEffect = 50, pEffect = 19}, [11] = {outfit = {lookType = 12}, useEffect = 33, pEffect = 14}, } local function delayed_magic_effect(cid) if not isCreature(cid) then return true end local outfit = getCreatureOutfit(cid) local tmp = TRANSFORMATIONS[outfit.lookType] if not tmp then return true end return addEvent(function() doSendMagicEffect(getCreaturePosition(cid), tmp.pEffect) delayed_magic_effect(cid) end, 1000) end function onSay(cid, words, param) local outfit = getCreatureOutfit(cid) local tmp = TRANSFORMATIONS[outfit.lookType] if not tmp then return doPlayerSendCancel(cid, "Você não possui mais transformações.") end local storage = outfit.lookType + 25000 if getCreatureStorage(cid, storage) < 1 then return doPlayerSendCancel(cid, "Você ainda não completou a quest necessária para usar essa transformação.") end doSendMagicEffect(getCreaturePosition(cid), tmp.useEffect) doSetCreatureOutfit(cid, tmp.outfit, -1) delayed_magic_effect(cid) return true end
-
local newMonster = doCreateMonster(getCreatureName(cid), pos) ._.'
-
Isso mesmo Oneshot, teria como fazer por exemplo para não aceitar qualquer tipo de runa/potion no trade porque se não tiraria o RPG do jogo dando trade à distância por exemplo para pegar pot para não sair da hunt. ACredito que com um evento em creaturescripts de, não? Na verdade, essa função ignora os creaturescripts. Então você teria que verificar, antes de usar, se o ID do item é uma potion, por exemplo.
-
Isso mesmo
-
Ele quer criar um atributo, por exemplo, chamado "increaseDropPercent" que aumente a chance de drop de itens em todos os monstros? Isso é fácil de fazer, no monsters.cpp ou monster.cpp, se não me engano. Talvez quando tiver algum tempo livre, tentarei fazer isso.
-
Por gentileza, se quiser prestar suporte a alguma pessoa do tópico, poderia fazer por MP e não postar aqui? Obrigado.
-
Tem muitos bugfixes diferentes, só isso que sei dizer. Abraços.
-
Você está pedindo muito, amigão, hehe... eu já disponibilizei a única trunk.r3777 que uso, compilada com o sistema. Abração.
-
Desculpa, pessoal. Estou trabalhando agora e sobra pouco tempo para o fórum, arrumei o erro do hideLevel que não consta de fato no monster.cpp, optei por não usar o modo que o Slicer passou e já atualizei o tópico. Como tem muita gente com dificuldade de compilar, estou disponibilizando as sources trunk.r3777 já com as alterações feitas, "infelizmente", por ser uma trunk.r3777 com muitos bugfixes disponibilizada na OtLand, não é possível compilar ela com Dev-Cpp, apenas com Code::Blocks. Já tem uma compilação GUI na pasta bin/GUI. É só fazer o download abaixo. Dropbox
-
resolvido Trocar vocação com magia e destrocar no login
pergunta respondeu ao daniursolinoo de Oneshot em Scripts
Não dou conta, cara, mas fica a dica pra quem "dá" Não use: doPlayerSetVocation(cid, vocation) Use: doPlayerSetPromotionLevel(cid, promotion) -
Mude isso: manapercent="10" Para mana="3150"
-
De fato, devo ter deixado algo passar, mas funciona perfeitamente do modo que passei. Enfim, sigam a ideia do Slicer. Abraços.
-
Então, declarei as duas variáveis que controlam o level mínimo e máximo como int32_t, isso significa um valor máximo possível igual a 2147483647. rs
-
Nasce com um level aleatório. Grande abraço.
-
Como funcionaria esse Race System? Pode passar mais detalhes por PM? rs Abraços.
-
Foi lançado ontem, neste tópico.
-
Monster Level Boa noite, Você deve ter visto este tópico e ficado interessado na feature, afinal, seria legal monstros terem também level, não é? O sistema que desenvolvi é bem funcional, o monstro passa a ter level e ganha mais HP, dá mais dano, tem mais defesa, dependendo dele. Como é feito em C++, a configuração é feita totalmente no XML do monstro, ficando tudo mais organizado. Há um extra no código, onde você pode manipular o level do summon do jogador, alterando o valor do storage 'monster_level'. Bom, é isso aí, para instalar, siga os passos a seguir atentamente. O sistema foi desenvolvido com base no The Forgotten Server 0.4_SVN r3777, não testei na versão 0.3.6, você tem a total liberdade para fazer isso. monsters.h Procure por: bool isSummonable, isIllusionable, isConvinceable, isAttackable, isHostile, isLureable, isWalkable, canPushItems, canPushCreatures, pushable, hideName, hideHealth; Substitua por: bool isSummonable, isIllusionable, isConvinceable, isAttackable, isHostile, isLureable, isWalkable, canPushItems, canPushCreatures, pushable, hideName, hideHealth, hideLevel; Procure por: int32_t defense, armor, health, healthMax, baseSpeed, lookCorpse, corpseUnique, corpseAction, maxSummons, targetDistance, runAwayHealth, conditionImmunities, damageImmunities, lightLevel, lightColor, changeTargetSpeed, changeTargetChance; Substitua por: int32_t defense, armor, health, healthMax, baseSpeed, lookCorpse, corpseUnique, corpseAction, maxSummons, targetDistance, runAwayHealth, conditionImmunities, damageImmunities, lightLevel, lightColor, changeTargetSpeed, changeTargetChance, levelMin, levelMax; monsters.cpp Procure por: canPushItems = canPushCreatures = isSummonable = isIllusionable = isConvinceable = isLureable = isWalkable = hideName = hideHealth = false; Substitua por: canPushItems = canPushCreatures = isSummonable = isIllusionable = isConvinceable = isLureable = isWalkable = hideName = hideHealth = hideLevel = false; Procure por: baseSpeed = 200; Logo abaixo, adicione: levelMin = levelMax = 1; Localize: bool Monsters::loadMonster Dentro da função, procure por: for(xmlNodePtr p = root->children; p; p = p->next) { if(p->type != XML_ELEMENT_NODE) continue; if(!xmlStrcmp(p->name, (const xmlChar*)"health")) { if(!readXMLInteger(p, "max", intValue)) { SHOW_XML_ERROR("Missing health.max"); monsterLoad = false; break; } mType->healthMax = intValue; if(!readXMLInteger(p, "now", intValue)) mType->health = mType->healthMax; else mType->health = intValue; } Logo abaixo, adicione: else if(!xmlStrcmp(p->name, (const xmlChar*)"level")) { if(!readXMLInteger(p, "max", intValue)) mType->levelMax = 1; else mType->levelMax = intValue; if(!readXMLInteger(p, "min", intValue)) mType->levelMin = mType->levelMax; else mType->levelMin = intValue; } Procure por: if(readXMLString(tmpNode, "emblem", strValue)) mType->guildEmblem = getEmblems(strValue); Logo abaixo, adicione: if(readXMLString(tmpNode, "hidelevel", strValue)) mType->hideLevel = booleanString(strValue); monster.h Localize: class Monster : public Creature { Logo abaixo de: public: #ifdef __ENABLE_SERVER_DIAGNOSTIC__ static uint32_t monsterCount; #endif virtual ~Monster(); Adicione: std::string name, nameDescription; int32_t level; double bonusAttack, bonusDefense; Substitua: virtual const std::string& getName() const {return mType->name;} virtual const std::string& getNameDescription() const {return mType->nameDescription;} virtual std::string getDescription(int32_t) const {return mType->nameDescription + ".";} Por: virtual const std::string& getName() const {return name;} virtual const std::string& getNameDescription() const {return nameDescription;} virtual std::string getDescription(int32_t) const {return nameDescription + ".";} monster.cpp Procure por: Monster::Monster(MonsterType* _mType): Logo abaixo de: isIdle = true; Adicione: name = _mType->name; nameDescription = _mType->nameDescription; level = (int32_t)random_range(_mType->levelMin, _mType->levelMax, DISTRO_NORMAL); bonusAttack = 1.0; bonusDefense = 1.0; Procure por: Monster::onCreatureAppear Substitua toda a função por: void Monster::onCreatureAppear(const Creature* creature) { Creature::onCreatureAppear(creature); if(creature == this) { //We just spawned lets look around to see who is there. if(isSummon()) { std::string value; this->master->getStorage((std::string)"monster_level", value); uint8_t intValue = atoi(value.c_str()); if(intValue || value == "0") level = intValue; else level = 1; isMasterInRange = canSee(master->getPosition()); } if(g_config.getBool(ConfigManager::MONSTER_HAS_LEVEL)) { this->healthMax = std::floor(this->getMaxHealth() * (1. + (0.1 * (level - 1)))); this->health = this->healthMax; this->bonusAttack += (0.01 * (level - 1)); this->bonusDefense += (0.005 * (level - 1)); } updateTargetList(); updateIdleStatus(); } else onCreatureEnter(const_cast<Creature*>(creature)); } Substitua todos: g_config.getDouble(ConfigManager::RATE_MONSTER_DEFENSE) Por: g_config.getDouble(ConfigManager::RATE_MONSTER_DEFENSE) * bonusDefense Substitua todos: g_config.getDouble(ConfigManager::RATE_MONSTER_ATTACK) Por: g_config.getDouble(ConfigManager::RATE_MONSTER_ATTACK) * bonusAttack map.cpp Procure por: #include "game.h" Adicione: #include "configmanager.h" Procure por: extern Game g_game; Adicione abaixo: extern ConfigManager g_config; Procure pela função: bool Map::placeCreature { Adicione logo depois: Monster* monster = creature->getMonster(); if(monster && g_config.getBool(ConfigManager::MONSTER_HAS_LEVEL)) { uint8_t level; if(!monster->getMonsterType()->hideLevel) { if(monster->isSummon()) { std::string value; monster->getMaster()->getStorage((std::string)"monster_level", value); uint8_t intValue = atoi(value.c_str()); if(intValue || value == "0") level = intValue; else level = 1; } else level = monster->level; char buffer [10]; monster->name = monster->getName() + " [" + itoa(level, buffer, 10) + "]"; } } configmanager.h Procure por: MONSTER_SPAWN_WALKBACK, E adicione abaixo: MONSTER_HAS_LEVEL, configmanager.cpp Procure por: m_loaded = true; Adicione um pouco antes: m_confBool[MONSTER_HAS_LEVEL] = getGlobalBool("monsterHasLevel", true); config.lua monsterHasLevel = true Acabou, ufa, né? São muitas modificações para fazer, mas o resultado é garantido e é uma funcionalidade a mais para seu servidor. Como está programado, a cada level, monstros ganham 10% de HP, 1% de dano e 0.5% de defesa. Para configurar level mínimo e máximo, é só adicionar no XML do monstro: <level min="1" max="10"/> E alterar a seu gosto. trunk.r3777 (com Monster Level) Espero que gostem, qualquer erro, só postar no tópico. Grande abraço.
-
Quem Está Navegando 0 membros estão online
- Nenhum usuário registrado visualizando esta página.