demuopl.h 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. * Adplug - Replayer for many OPL2/OPL3 audio file formats.
  3. * Copyright (C) 1999 - 2005 Simon Peter, <dn.tlp@gmx.net>, et al.
  4. *
  5. * This library is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU Lesser General Public
  7. * License as published by the Free Software Foundation; either
  8. * version 2.1 of the License, or (at your option) any later version.
  9. *
  10. * This library is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  13. * Lesser General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU Lesser General Public
  16. * License along with this library; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  18. *
  19. * demuopl.h - Emulated OPL using DOSBOX's emulator, by Wei Mingzhi
  20. * <whistler_wmz@users.sf.net>.
  21. */
  22. #ifndef H_ADPLUG_DEMUOPL
  23. #define H_ADPLUG_DEMUOPL
  24. #include "opl.h"
  25. #include "dosbox_opl.h"
  26. #include <assert.h>
  27. class CDemuopl: public Copl
  28. {
  29. public:
  30. CDemuopl(int rate, bool bit16, bool usestereo)
  31. :use16bit(bit16), stereo(usestereo)
  32. {
  33. adlib_init(rate);
  34. currType = TYPE_OPL2;
  35. };
  36. void update(short *buf, int samples)
  37. {
  38. short *mixbuf0 = new short[samples*2],*mixbuf1 = new short[samples*2];
  39. short *outbuf;
  40. if(use16bit) outbuf = buf;
  41. else outbuf = mixbuf1;
  42. //if(use16bit) samples *= 2;
  43. //if(stereo) samples *= 2;
  44. adlib_getsample(outbuf, samples);
  45. if(stereo)
  46. for(int i=samples-1;i>=0;i--) {
  47. outbuf[i*2] = outbuf[i];
  48. outbuf[i*2+1] = outbuf[i];
  49. }
  50. //now reduce to 8bit if we need to
  51. if(!use16bit)
  52. for(int i=0;i<(stereo ? samples*2 : samples);i++)
  53. ((char *)buf)[i] = (outbuf[i] >> 8) ^ 0x80;
  54. delete[] mixbuf0; delete[] mixbuf1;
  55. }
  56. // template methods
  57. void write(int reg, int val)
  58. {
  59. if(currChip == 0)
  60. adlib_write(reg, val);
  61. };
  62. void init() {};
  63. protected:
  64. bool use16bit,stereo;
  65. };
  66. #endif