Шрифт в постах

Стиль оформления

Дополнительно

вверх
вниз

Shadows of Old

Информация о пользователе

Привет, Гость! Войдите или зарегистрируйтесь.


Вы здесь » Shadows of Old » Анкетирование » Branwen ni Alva | ayre


Branwen ni Alva | ayre

Сообщений 1 страница 3 из 3

1

БРАНВЕН НИ АЛЬВА | BRANWEN NI ALVA
целительница

https://upforme.ru/uploads/001c/03/d9/271/243747.png

около 200 лет | айре | Аравель

••••••••••••••••••••••••••••••••••••••••••••

Образ персонажа

• Среди всех анклавов айре Дал Ангра обладала наибольшим запасом терпения к младшим расам, и Бранвен с юных лет была уверена, что это правильно. Вслед за отцом, много путешествовавшим по людским землям и протянувшим когда-то руку помощи королевству Эйдин, она вызвалась стать эмиссаром в Кайр Лаэде. Несколько десятилетий Бранвен терпеливо возводила мост между айре и людьми, мягко давала советы королю Телврину и учила магии его детей. Она полагала, что даже этот вздорный народ, кровь от крови безумных гигантов, можно привести к порядку и просветлению.

• Она ещё никогда так не ошибалась. Канцлер Маравин, с которым они часто и подолгу разговаривали о будущем за вином, замыслил предательство и подготовил убийцу лично для неё — совершенного убийцу, который мог совладать с силой айре; который почти обманул её бдительность, почти лишил жизни в самом расцвете. Бранвен ускользнула, израненная физически и душевно; сумела даже забрать с собой маленького Гавейна, но больше ей никого не удалось спасти.

• Раны на теле затянулись однажды, но в душе навеки поселилось разочарование в людях, не умевших ценить добро, не думавших хотя бы на шаг вперёд, не оправдавших возложенных на них надежд. И всё же сердце Бранвен дрогнуло дважды: когда Гавейн, целый год молчавший после пережитого ужаса, обнял её и заплакал, как должны плакать напуганные дети; когда в Аравель пришёл Риан, живой и мёртвый одновременно, с кровоточащим порезом на шее.

• Бранвен не отдала ему племянника. Риан хотел войны и отмщения, рвался безудержно в кровавое болото, строил планы по свержению Маравинов — значит, неизбежно потащил бы Гавейна за собой. Теперь на ней лежали камнем две вины: за то, что не помогла в Ночь Ножей, и за то, что скрыла выжившего родственника. Чтобы расплатиться по счетам, Бранвен решила помочь людям, которых Риан взял под опеку: скудная земля в предгорьях с трудом могла их прокормить, но Бранвен было по силам сделать растения выносливее, животных — здоровее, почву — богаче. Она больше не хотела любить это племя и заботится о его благе, но в первый урожайный год лицо Риана стало светлее. Все труды того стоили.

• Хрупкое равновесие продержалось недолго. Вслед за беженцами в Аравель потянулась нежить, вслед за нежитью — воры и некроманты; драконьи курганы задрожали от негодования, а наиболее воинственные сородичи вновь заговорили об очищении долины. Бранвен заколебалась вновь: изгнать людей сейчас — не то же самое, что сорвать с молодой яблони повилику; скорее уж выкорчевать дерево целиком. Слишком много ран будет нанесено земле, слишком много живого пострадает; айре, которые нанесут удар, тоже перестанут быть похожими на самих себя. Бранвен желала им другого будущего.

• Когда заговорили о драконах, явившихся некоторым потомкам, она не поверила: слишком много скверны разлилось по долине в последние дни, слишком много боли и горечи отравило воздух. Пытаясь найти ответы, Бранвен начала обходить анклавы один за другим и разговаривать с сородичами. Рано или поздно она должна была найти тех, кто слышал голоса. Рано или поздно она должна была понять, снизошли к ним великие предки или беды Аравеля только начинались.

Дополнительная информация

• Ближайшие родственники:
    Ллир мак Бренна — отец, айре, артефактор из Дал Ангры
    Альва ни Шэй — мать, айре, целительница из Дал Ангры; ушла в Подгорье после совершеннолетия Бранвен
    Риан ан Эльтайн — племянник, вампир, владыка людей Аравеля
    Гавейн ан Эльтайн — приёмный сын и ученик, полуайре

• Вместе с отцом занимается исследованием скверны и поиском лекарства против увядания, поразившего анклавы айре. Восстанавливает леса и защищает заповедные места от браконьеров. Приглядывает за человеческими поселениями, чтобы те не голодали и пили чистую воду.

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

• Чтобы сохранить гармонию с природой, не ест мясо и не носит мех. Тонкие струящиеся одежды, в которых её обычно видят, шьёт из зачарованного паучьего шёлка; в них не холодно зимой и не жарко летом.

Планы игру, пожелания по сюжетам и игровые табу

• Время радовать папу, волновать Наира, выкидывать культистов из долины и помогать двудушникам. Возможно, людям тоже — смотря как будут себя вести.
• Не играю пытки, сексуальное насилие, заключение, лишение контроля. Если что-то из этого списка нужно по сюжету, приемлемо упомянуть, что таковое было, не вдаваясь в подробности.

Что делать с вашим персонажем в случае ухода с проекта

• Передать в добрые руки <3

Пример поста

https://i.imgur.com/cILgtlW.gif

Отредактировано Branwen ni Alva (2025-12-06 15:54:32)

Подпись автора

ГарретЛисАлияРахманЛеорикБранвен

+8

2

Вы приняты, добро пожаловать!

Коды для заполнения (следующим сообщением в теме анкеты):
Заполните поля во вкладках "Основа", "Профиль", "Плашка", "Фон" и нажмите на кнопку "Скопировать код" ниже, чтобы скопировать заполненные шаблоны.

[html]
<script>
// --------- FILL BACKGROUNDS ------------

function labelBg(className, nameCategory, src) {
    return `<label class="${className}"><input type="radio" name="${nameCategory}" id="${src}" onchange="updateProfilePreview()"><img src="${src}" loading="lazy"> </label>`;
}

function fillBgs(bgs) {
    document.getElementById('bgContainer').innerHTML = bgs
        .map(bg => labelBg("profileBgLabel", "profileBg", bg)).join('');
}

// --------- FILL STRIPES ------------

function labelStripe(className, nameCategory, src) {
    return `<label class="${className}"><input type="radio" name="${nameCategory}" id="${src}" onchange="updateProfilePreview()"><img src="${src}"> </label>`;
}

function fillStripes(stripes) {
    document.getElementById('stripeContainer').innerHTML = stripes
        .map(stripe => labelStripe("profileStripeLabel", "profileStripe", stripe)).join('');
}

// --------- USER DATA ------------

let userLatinName = '';
let userProfileUrl = '';
let userApplicationFormUrl = '';

window.addEventListener("message", (event) => {
    if (!event.origin.match(/oldshadows\.rusff\.me$/)) return;
    if (event.data.eventName != 'profileFillingResponce') return;
    userLatinName = event.data.userLatinName;
    userProfileUrl = event.data.userProfileUrl;
    userApplicationFormUrl = event.data.userApplicationFormUrl;
    fillStripes(event.data.stripes);
    fillBgs(event.data.backgrounds);
});

window.addEventListener("message", (event) => {
    if (!event.origin.match(/oldshadows\.rusff\.me$/)) return;
    if (event.data.eventName != 'fontChange') return;
    $('.post-content p, .post-content div').css('font-size', event.data.fontSize + 'px');
});

const sendProfileRequest = () => {
    window.parent.postMessage({ eventName: 'profileFillingRequest' }, "*");
};
sendProfileRequest();
const intervalId = setInterval(sendProfileRequest, 1000);
window.addEventListener("message", (event) => {
    if (!event.origin.match(/oldshadows\.rusff\.me$/)) return;
    if (event.data.eventName === 'profileFillingResponce') {
        clearInterval(intervalId);
    }
});

function copyResults() {
    let copyContent = '';
   
    // -- форма внешности --
    const actorName = document.getElementById('actor').value;
    if (actorName) {
        const actorForm = `${actorName} — ${String.fromCharCode(91)}url=${userProfileUrl}${String.fromCharCode(93)}${userLatinName}${String.fromCharCode(91)}/url${String.fromCharCode(93)}`;
        copyContent += `Форма внешности: 
${String.fromCharCode(91)}code${String.fromCharCode(93)}${actorForm}${String.fromCharCode(91)}/code${String.fromCharCode(93)}`;
    }

    // -- форма заполнения профиля --
    const cyrillicName = document.getElementById('cyrillicName').value;
    if (cyrillicName) {
        const profileDescrName = document.getElementById('mainDescr').value;
        let profileForm = `<a href='${userApplicationFormUrl}'>${cyrillicName}</a>, ${profileDescrName}`;
       
        if (document.getElementById('hrAdd').checked) {
            profileForm += '<hr>';
        } else {
            profileForm += '<br>';
        }
       
        const profileAdd = document.getElementById('addDescr').value;
        const profileAddNotFilled = profileAdd == '' || profileAdd == `любое описание на ваш вкус <a href='ссылка на анкету персонажа'>имя на кириллице</a>`;
        if (!profileAddNotFilled) {
            profileForm += profileAdd;
        }
       
        copyContent += `\n\nФорма профиля:
${String.fromCharCode(91)}code${String.fromCharCode(93)}${profileForm}${String.fromCharCode(91)}/code${String.fromCharCode(93)}\n\n`;
    }

    // -- форма плашки --
    const stripeForm = Array.from(document.getElementsByName('profileStripe'))
        .filter(element => element.checked)
        .map(element => element.id)
        .join('');

    if (stripeForm) {
        copyContent += `Плашка:
${String.fromCharCode(91)}img${String.fromCharCode(93)}${stripeForm}${String.fromCharCode(91)}/img${String.fromCharCode(93)}\n\n`;
    }

        // -- форма фона --
    const bgForm = Array.from(document.getElementsByName('profileBg'))
        .filter(element => element.checked)
        .map(element => element.id)
        .join('');

    if (bgForm) {
        copyContent += `Фон:
${String.fromCharCode(91)}img${String.fromCharCode(93)}${bgForm}${String.fromCharCode(91)}/img${String.fromCharCode(93)}\n\n`;
    }

    // -- форма списка ролей --
    const listsDescription = document.getElementById('listsDescription').value;
    if (cyrillicName && listsDescription) {
        const listsForm = `${String.fromCharCode(91)}url=${userProfileUrl}${String.fromCharCode(93)}${cyrillicName}${String.fromCharCode(91)}/url${String.fromCharCode(93)} — ${listsDescription}`;
        copyContent += `Список ролей:
${String.fromCharCode(91)}code${String.fromCharCode(93)}${listsForm}${String.fromCharCode(91)}/code${String.fromCharCode(93)}\n\n`;
    }

    window.parent.postMessage({
        eventName: 'profileCopyInfoRequest',
        copyData: copyContent.trim() // Удаляем лишние переносы в конце
    }, "*");
};

document.getElementById('instructionResult').onclick = copyResults;

// --------- post user profile update ------------
function updateProfilePreview() {
    const cyrillicName = document.getElementById('cyrillicName').value ?? userLatinName;
    const profileDescrName = document.getElementById('mainDescr').value;
    let profileForm = `<a href='${userApplicationFormUrl}'>${cyrillicName}</a>, ${profileDescrName}`;
   
    if (document.getElementById('hrAdd').checked) {
        profileForm += '<hr>';
        } else {
            profileForm += '<br>';
        }   
    const profileAdd = document.getElementById('addDescr').value;
    const profileAddNotFilled = profileAdd == '' || profileAdd == `любое описание на ваш вкус <a href='ссылка на анкету персонажа'>имя на кириллице</a>`;
    if (!profileAddNotFilled) {
        profileForm += profileAdd;
    }

    const stripeForm = Array.from(document.getElementsByName('profileStripe'))
        .filter(element => element.checked)
        .map(element => element.id)
        .join('');

    const bgForm = Array.from(document.getElementsByName('profileBg'))
        .filter(element => element.checked)
        .map(element => element.id)
        .join('');

    window.parent.postMessage({
        eventName: 'profileDemo',
        profileDescr: profileForm,
        stripe: stripeForm,
        background: bgForm
    }, "*");
}

updateProfilePreview();

window.addEventListener("message", (event) => {
    if (!event.origin.match(/oldshadows\.rusff\.me$/)) return;
    if (event.data.eventName != 'fontChange') return;
    $('.post-content p, .post-content div').css('font-size', event.data.fontSize + 'px');
});

window.addEventListener("message", (event) => {
    if (!event.origin.match(/oldshadows\.rusff\.me$/)) return;
    if (event.data.eventName != 'styleChange') return;
    $("body").attr("class", event.data.style);
});
</script>

<div class="fillingForm">
<label class="fillingCategoryRadio"><input type="radio" id="main" name="fillingCategoryRadio" checked /> <span>Основа</span></label>
<label class="fillingCategoryRadio"><input type="radio" id="profileF" name="fillingCategoryRadio" /> <span>Профиль</span></label>
<label class="fillingCategoryRadio"><input type="radio" id="stripesF" name="fillingCategoryRadio" /> <span>Плашка</span></label>
<label class="fillingCategoryRadio"><input type="radio" id="bgsF" name="fillingCategoryRadio" /> <span>Фон</span></label>

<div class="instructionBlock mainInstruction">
<h2 class="instructionHeading">Основа</h2>
<label for="cyrillicName" class="labelDescr">Имя (кирилица):</label>
<input type="text" id="cyrillicName" name="cyrillicName" placeholder="кириллица" oninput="updateProfilePreview()">

<label for="actor" class="labelDescr">Внешность (латиница):</label>
<input type="text" id="actor" name="actor" placeholder="если не нужно, оставьте поле пустым">

<label for="listsDescription" class="labelDescr">Описание для списка ролей:</label>
<input type="text" id="listsDescription" name="listsDescription" placeholder="род деятельности, занятость">
</div>

<div class="instructionBlock profileInstruction">
<h2 class="instructionHeading">Описание в профиль</h2>
<label for="mainDescr" class="labelDescr">Описание в профиль:</label>
<input type="text" id="mainDescr" name="mainDescr" value="возраст, раса, род деятельности" oninput="updateProfilePreview()">

<label for="hrAdd" class="hrAdd">
<input type="checkbox" id="hrAdd" name="hrAdd" onchange="updateProfilePreview()" />
<span>Добавить полосу между секциями</span>
</label>

<label for="addDescr" class="labelDescr">При желании можете добавить в профиль пару, красивую цитату, важного родственника, врага и тому подобное через это поле. Если не нужно, оставьте его пустым или не меняйте:</label>
<textarea id="addDescr" oninput="updateProfilePreview()" name="addDescr" rows="4">любое описание на ваш вкус <a href='ссылка на анкету персонажа'>имя на кириллице</a></textarea>
</div>

<div class="instructionBlock stripeInstruction">
<h2 class="instructionHeading">Плашки</h2>
<div id="stripeContainer"></div>
</div>

<div class="instructionBlock bgInstruction">
<h2 class="instructionHeading">Фоны</h2>
<div id="bgContainer"></div>
</div>

<div class="formButtons">
<input type="button" id="instructionResult" value="Скопировать код">
</div>
</div>

<style>
body { color: var(--text1); }

h2.instructionHeading {
    font-size: 16px;
    font-family: 'Palatino Linotype';
    font-weight: bold;
    letter-spacing: 1px;
}

.labelDescr {
    display: block;
    margin: 9px 0px 1px 0px;
}

.fillingForm { text-align: center; }

.instructionBlock {
    text-align: left;
    margin: 10px 0 !important;
    padding: 14px 14px 12px 14px !important;
    border: 1px solid var(--borders);
    background: var(--qBG);
    border-radius: 4px;
}

.instructionBlock input[type="text"] {
    width: calc(100% - 10px);
}

label.hrAdd {
    margin: 10px 0 0 0;
    display: block;
}

input#hrAdd  {
    accent-color: var(--darkpinkText);
}

label.fillingCategoryRadio {
    border-radius: 16px;
    border: 1px solid var(--borders);
    background: var(--beg300);
    padding: 2px 6px;
    display: inline-block;
    margin: 0px 4px 5px 0px;
}

.instructionBlock textarea {
    width: calc(100% - 10px);
    resize: vertical;
}

label.fillingCategoryRadio:has(input:checked) {
    background: var(--borders);
    color: var(--text1);
}

.fillingCategoryRadio input[type="radio"] {
    display: none;
}

label.fillingCategoryRadio {
    cursor: pointer;
}

.mainInstruction, .profileInstruction, .stripeInstruction, .bgInstruction { display: none; }
.fillingCategoryRadio:has(#main:checked) ~ .mainInstruction { display: block !important; }
.fillingCategoryRadio:has(#profileF:checked) ~ .profileInstruction { display: block !important; }
.fillingCategoryRadio:has(#stripesF:checked) ~ .stripeInstruction { display: block !important; }
.fillingCategoryRadio:has(#bgsF:checked) ~ .bgInstruction { display: block !important; }

.profileStripeLabel, .profileBgLabel {
    margin: 5px 5px;
    display: inline-block;
    width: 180px;
    border-radius: 5px;
    padding: 5px;
    background: rgb(255 255 255 / 17%);
}

.profileStripeLabel img, .profileBgLabel img { border-radius: 3px; }
.profileBgLabel img {
    width: 180px;
    height: 40px;
    object-fit: cover;
    object-position: top;
}

.profileStripeLabel input, .profileBgLabel input { display: none; }

.profileStripeLabel:has(input:checked), .profileBgLabel:has(input:checked) {
    background: rgb(0 0 0 / 12%);
}

div#stripeContainer, div#bgContainer  {
    align-items: baseline;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-content: flex-start;
    height: 190px;
    overflow-x: auto;
    overflow-y: hidden;
}

</style>
[/html]

0

3

ХРОНОЛОГИЯ

[04.06.525] А в этой башне истинное волшебство
Бранвен восстанавливается после ранения в башне отца, где её неожиданно навещает Наир.

[18.10.540] Береги себя
Не то чтобы в леса Аравеля редко забредают чужаки, но этот особенный — он даёт Бранвен шанс вернуть старый долг.

[26.11.585] Curses are my endless muse
Осквернённый лес медленно умирает. Хранители ищут способ помочь.

Отредактировано Branwen ni Alva (2025-12-23 18:02:34)

Подпись автора

ГарретЛисАлияРахманЛеорикБранвен

0


Вы здесь » Shadows of Old » Анкетирование » Branwen ni Alva | ayre


Рейтинг форумов | Создать форум бесплатно