Logo Search packages:      
Sourcecode: yoshimi version File versions  Download package


    Microtonal.h - Tuning settings and microtonal capabilities

    Original ZynAddSubFX author Nasca Octavian Paul
    Copyright (C) 2002-2005 Nasca Octavian Paul
    Copyright 2009, Alan Calvert

    This file is part of yoshimi, which is free software: you can redistribute
    it and/or modify it under the terms of version 2 of the GNU General Public
    License as published by the Free Software Foundation.

    yoshimi is distributed in the hope that it will be useful, but WITHOUT ANY
    WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
    FOR A PARTICULAR PURPOSE.   See the GNU General Public License (version 2 or
    later) for more details.

    You should have received a copy of the GNU General Public License along with
    yoshimi; if not, write to the Free Software Foundation, Inc., 51 Franklin
    Street, Fifth Floor, Boston, MA  02110-1301, USA.

    This file is a derivative of the ZynAddSubFX original, modified October 2009


#include <cstring>

using namespace std;

#include "Misc/XMLwrapper.h"

#define MAX_OCTAVE_SIZE 128

class Microtonal
        Microtonal() { };
        ~Microtonal() { };
        void defaults(void);
        float getnotefreq(int note, int keyshift);

        // Parameters
        unsigned char Pinvertupdown;
        unsigned char Pinvertupdowncenter;
        unsigned char Penabled;
        unsigned char PAnote;
        unsigned char Pscaleshift;
        float PAfreq;

        // first and last key (to retune)
        unsigned char Pfirstkey;
        unsigned char Plastkey;

        // The middle note where scale degree 0 is mapped to
        unsigned char Pmiddlenote;

        // Map size
        unsigned char Pmapsize;

        // Mapping ON/OFF
        unsigned char Pmappingenabled;
        // Mapping (keys)
        short int Pmapping[128];

        unsigned char Pglobalfinedetune;

        // Functions
        unsigned char getoctavesize(void);
        void tuningtoline(int n, char *line, int maxn);
        int loadscl(string filename); // load the tunnings from a .scl file
        int loadkbm(string filename); // load the mapping from .kbm file
        int texttotunings(const char *text);
        void texttomapping(const char *text);
        string Pname;
        string Pcomment;

        void add2XML(XMLwrapper *xml);
        void getfromXML(XMLwrapper *xml);
        bool saveXML(string filename);
        bool loadXML(string filename);

        int linetotunings(unsigned int nline, const char *line);
        int loadline(FILE *file, char *line);
            // loads a line from the text file,
            // ignoring the lines beggining with "!"
        unsigned char octavesize;
        struct {
            unsigned char type; // 1 for cents or 2 for division
            // the real tuning (eg. +1.05946 for one halftone)
            // or 2.0 for one octave
            float tuning;
            unsigned int x1, x2; // the real tunning is x1/x2
        } octave[MAX_OCTAVE_SIZE],

      unsigned int samplerate;
      int buffersize;
      int oscilsize;


Generated by  Doxygen 1.6.0   Back to index