deck.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. #include "door.h"
  2. #include <random>
  3. #include <string>
  4. #include <utility> // pair
  5. #include <vector>
  6. /*
  7. I tried card_height = 5, but the cards looked a little too stretched out/tall.
  8. 3 looks good.
  9. layout, rev2:
  10. 12345678901234567890123456789012345678901234567890123456789012345678901234567890
  11. +---------------------------------+
  12. Space Ace - Tri-Peaks Solitaire
  13. +---------------------------------+
  14. Cards start at 0, not 1!
  15. ░░1░░ ░░2░░ ░░3░░
  16. ░░░░░ ░░░░░ ░░░░░
  17. ▒▒4▒▒░░░▒▒5▒▒ ##6##░░░##7## ##8##░░░##9##
  18. ▒▒▒▒▒ ▒▒▒▒▒ ##### ##### ##### #####
  19. ▓▓10▓▒▒▒▓▓11▓▒▒▒▓▓12▓ ##13#===##14#===##15# ##16#===##17#===##18#
  20. ▓▓▓▓▓ ▓▓▓▓▓ ▓▓▓▓▓ ##### ##### ##### ##### ##### #####
  21. ██19█▓▓▓██20█▓▓▓██21█▓▓▓##22#===##23#===##24#===##25#===##26#===##27#===##28#
  22. █████ █████ █████ ##### ##### ##### ##### ##### ##### #####
  23. █████ █████ █████ ##### ##### ##### ##### ##### ##### #####
  24. Name: ##30# --29- Playing: December 31
  25. Score: ##### ----- Current Streak: nn
  26. Time used: xxx / XXX left ##### ----- Longest Streak: nn
  27. Playing Hand X of X Cards left XX
  28. 1234567890123456789012345 123456789012345 12345678901234567890
  29. [4/<] Left [6/>] Right [Space] Play Card [Enter] Draw [Q]uit [R]edraw [H]elp
  30. ^ -- above is 20 lines from +-- to [4/<] < Left
  31. score_panel left_panel streak_panel
  32. command_panel
  33. #####
  34. Player Information ##### Time in: xx Time out: xx
  35. Name: ##### Playing Day: November 3rd
  36. Hand Score : Current Streak: N
  37. Todays Score : XX Cards Remaining Longest Streak: NN
  38. Monthly Score: Playing Hand X of X Most Won: xxx Lost: xxx
  39. [4] Lf [6] Rt [Space] Play Card [Enter] Draw [D]one [H]elp [R]edraw
  40. layout, rev1:
  41. ░░░░░ ░░░░░ ░░░░░
  42. ░░░░░ ░░░░░ ░░░░░
  43. ▒▒▒▒▒░▒▒▒▒▒ #####░##### #####░#####
  44. ▒▒▒▒▒ ▒▒▒▒▒ ##### ##### ##### #####
  45. ▓▓▓▓▓▒▓▓▓▓▓▒▓▓▓▓▓ #####=#####=##### #####=#####=#####
  46. ▓▓▓▓▓ ▓▓▓▓▓ ▓▓▓▓▓ ##### ##### ##### ##### ##### #####
  47. █████▓█████▓█████▓#####=#####=#####=#####=#####=#####=#####
  48. █████ █████ █████ ##### ##### ##### ##### ##### ##### #####
  49. █████ █████ █████ ##### ##### ##### ##### ##### ##### #####
  50. #####
  51. Player Information ##### Time in: xx Time out: xx
  52. Name: ##### Playing Day: November 3rd
  53. Hand Score : Current Streak: N
  54. Todays Score : XX Cards Remaining Longest Streak: NN
  55. Monthly Score: Playing Hand X of X Most Won: xxx Lost: xxx
  56. [4] Lf [6] Rt [Space] Play Card [Enter] Draw [D]one [H]elp [R]edraw
  57. Spacing 1 or 3. 1 is what was used before, 3 looks better, takes up more
  58. screenspace. And I have plenty, even on 80x23.
  59. TODO: Have functions that gives me:
  60. int deck(int c); // which deck #
  61. int suit(int c); // suit
  62. int rank(int c); // rank
  63. */
  64. typedef std::vector<int> cards;
  65. class Deck {
  66. private:
  67. door::ANSIColor cardback;
  68. vector<door::Panel *> cards;
  69. vector<door::Panel *> backs;
  70. vector<door::Panel *> mark;
  71. door::Panel *card_of(int c);
  72. std::string back_char(int level);
  73. door::Panel *back_of(int level);
  74. door::Panel *mark_of(int c);
  75. void init(void);
  76. char rank_symbol(int c);
  77. std::string suit_symbol(int c);
  78. int card_height;
  79. public:
  80. enum SUIT { HEART, DIAMOND, CLUBS, SPADE };
  81. Deck(int size = 3);
  82. Deck(door::ANSIColor backcolor, int size = 3);
  83. ~Deck();
  84. int is_rank(int c);
  85. int is_suit(int c);
  86. int is_deck(int c);
  87. /**
  88. * @brief Can this rank play on this other rank?
  89. *
  90. * @param c1
  91. * @param c2
  92. * @return true
  93. * @return false
  94. */
  95. bool can_play(int c1, int c2);
  96. door::Panel *card(int c);
  97. /**
  98. * @brief Return panel for back of card.
  99. *
  100. * 0 = Blank
  101. * 1 = level 1 (furthest/darkest)
  102. * 2 = level 2
  103. * 3 = level 3
  104. * 4 = level 4 (closest/lightest)
  105. *
  106. * 5 = left (fills with left corner in place)
  107. * 6 = right (fills right corner)
  108. * 7 = both (fills both corners)
  109. *
  110. * @param level
  111. * @return door::Panel*
  112. */
  113. door::Panel *back(int level);
  114. door::Panel *marker(int c);
  115. void part(int x, int y, door::Door &d, int level, bool left);
  116. std::vector<int> unblocks(int c);
  117. const static std::array<std::pair<int, int>, 18> blocks;
  118. void remove_card(door::Door &door, int c, int off_x, int off_y, bool left,
  119. bool right);
  120. };
  121. /**
  122. * @brief Given a position, space=3, height=3, return x,y and level.
  123. *
  124. * This is the older version that allows for space and h "height"
  125. * to be variable. I'd rather have one that has them as constants.
  126. *
  127. * @param pos
  128. * @param space
  129. * @param h
  130. * @param x
  131. * @param y
  132. * @param level
  133. */
  134. [[deprecated("Use cardgo(int pos, int &x, int &y, int &level")]] void
  135. cardgo(int pos, int space, int h, int &x, int &y, int &level);
  136. /**
  137. * @brief Where does this card go?
  138. *
  139. * This finds x, y, and the level (for the card background)
  140. *
  141. * @param pos
  142. * @param x
  143. * @param y
  144. * @param level
  145. */
  146. void cardgo(int pos, int &x, int &y, int &level);
  147. /**
  148. * @brief shuffle deck of cards
  149. *
  150. * example of seeding the deck for a given date 2/27/2021 game 1
  151. * std::seed_seq s1{2021, 2, 27, 1};
  152. * vector<int> deck1 = card_shuffle(s1, 1);
  153. * @param seed
  154. * @param decks
  155. * @return vector<int>
  156. */
  157. cards card_shuffle(std::seed_seq &seed, int decks = 1);
  158. cards card_states(int decks = 1);
  159. /**
  160. * @brief Find the next card to move to.
  161. *
  162. * if (left) .. to the left, otherwise right
  163. * current is the current position we're on.
  164. *
  165. * return -1 failed to find anything.
  166. * @param left
  167. * @param states
  168. * @param current
  169. * @return int
  170. */
  171. int find_next(bool left, const cards &states, int current);