реклама на сайте
подробности

 
 
> Convert 16-bit integer to ASCII with comma and signum, сделайте красиво
ViKo
сообщение Sep 7 2017, 11:44
Сообщение #1


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Есть 16-битовый знаковый результат с АЦП, нужно написать его в виде строки с целой и дробной частями и точкой в заданной позиции. Например, 336 нужно изобразить в виде +3.36. С выравниванием по правому краю. Рабочий пример показываю ниже. Использую буфер на 8 символов. Конец строки тоже входит в буфер, и поэтому число -0.32109 не помещается, будет выводиться в виде -.32109 (может, и не стоило так ограничиваться, но это позже всплыло). Пример не очень нравится, просто на скорую руку слепил. Если кому интересно поупражняться в программировании, покажите, как можно.
CODE

/*!*************************************************************************
@brief 16-bit integer convert to ASCII with comma and signum
@param num - число для преобразования
@param str - строка из 8 символов: знак, цифры, точка, конец строки
@param pointpos - позиция точки в строке (1..6, количество мест перед ней)
@param showplus - записывать символ '+'
@note при pointpos = 0, > 6 - точка не ставится
*/
void Half2TextPoint_conv(int16_t num, char *str, uint32_t pointpos, bool showplus)
{
char *strleft = str; // левая граница строки (только для знака)
*(uint32_t *)(str ) = ' ' | ' ' << 8 | ' ' << 16 | ' ' << 24;
*(uint32_t *)(str + 4) = ' ' | ' ' << 8 | ' ' << 16 | '\0'<< 24;
bool fract = true; // дробная часть рассчитана или не нужна
if (pointpos >= 1 && pointpos <= 6) {
*(str + pointpos) = '.';
fract = false; // дробная часть нужна, пока не получена
}
char sign = ' ';
if (showplus)
sign = '+';
if (num < 0) {
sign = '-';
num = -num;
}
str += 6;
do {
if (*str == '.') {
str--;
fract = true;
}
*str = num % 10 + '0';
str--;
} while ((num /= 10) || !fract); // пока нужна дробная часть
if (str < strleft) str++; // проскочили из-за запятой в поз. 1 и числа < 1
*str = sign;
}
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Jenya7
сообщение Oct 1 2017, 13:12
Сообщение #2


Профессионал
*****

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



После долгих мытарств решил делать так
Код
static inline int IntToStr(int x, char str[], int d)
{
    int i = 0;
    
     do { str[i++] = (x % 10) + '0'; }
     while ((x /= 10) > 0);
    
    // If number of digits required is more, then
    // add 0s at the beginning
    while (i < d)
        str[i++] = '0';

    Reverse(str, i);
    str[i] = '\0';
    return i;
}

void FtoA(float n, char *res, int afterpoint)
{
    int ap = afterpoint;
    
     //signed?
    if(n < 0)
    {
        n *= -1;
        *res = '-';
        res++;
    }
    
    // Extract integer part
    int ipart = (int)n;
    
    // Extract floating part
    float fpart = n - (float)ipart;
        
    // convert integer part to string
    int i = IntToStr(ipart, res, 0);

    // check for display option after point
    if (afterpoint != 0)
    {
        res[i] = '.';  // add dot

        // Get the value of fraction part up to given no.
        // of points after dot. The third parameter is needed
        // to handle cases like 233.007
        //fpart = fpart * pow(10, afterpoint);
        while (ap)
        {
            fpart *= 10;
            ap--;
        }

        IntToStr((int)fpart, res + i + 1, afterpoint);
    }
}

хотя это немного не то что требуется. ну пусть висит.

Сообщение отредактировал Jenya7 - Oct 1 2017, 13:16
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 19th July 2025 - 05:30
Рейтинг@Mail.ru


Страница сгенерированна за 0.01371 секунд с 7
ELECTRONIX ©2004-2016