发牌程序(二)

package SendCardcopy;

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.Action;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;

public class DealCard {
	SendCardThread sendcardthread;
	ReceiveCardThread[] receivecardthreadds;

	public DealCard(int cardMax, int personNumber) {
		CardBuffer cardbuffer = new CardBuffer(personNumber);
		sendcardthread = new SendCardThread(cardbuffer, cardMax);
		String[] titles = { "北", "东", "南", "西" };
		int[] x = { 300, 550, 300, 50 };
		int[] y = { 200, 320, 440, 320 };
		receivecardthreadds = new ReceiveCardThread[personNumber];
		for (int i = 0; i < personNumber; i++) {
			receivecardthreadds[i] = new ReceiveCardThread(sendcardthread,cardbuffer, i, titles[i], x[i], y[i]);
		}

	}

	public static void main(String[] args) {
		new DealCard(52, 4);// 52张牌,4个人收
	}
}

class CardBuffer {
	private int personNumber;// 多少人接收
	private int value;
	private int order;// 接牌的循序
	private boolean isEmpty;// 旗杆标志

	public CardBuffer(int personNumber) {
		this.personNumber = personNumber;
		isEmpty = true;
		order = 0;
	}

	public synchronized void put(int value) {
		while (!isEmpty) {// 要放入数据,必须buffer为空
			try {
				this.wait();
			} catch (InterruptedException e) {
				System.out.println("buffer不为空,等待异常!!");
			}
		}
		this.value = value;
		isEmpty = !isEmpty;
		this.notifyAll();
	}

	public synchronized int get(int order) {
		while (isEmpty || this.order != order) {// 只有是有序的人才能接收
			try {
				this.wait();
			} catch (InterruptedException e) {
				System.out.println("buffer为空,等待异常!!");
			}
		}
		isEmpty = !isEmpty;
		this.notifyAll();
		this.order = (this.order + 1) % this.personNumber;// 有序发牌
		return value;
	}

}

class SendCardThread extends JFrame implements Runnable {
	private CardBuffer buffer;
	private int cardMax;
	private int[] cardNumber;// 0 1 2 3 4 5 .... 51
	JTextArea text_area;
	JPanel pnl;

	public SendCardThread(CardBuffer buffer, int cardMax) {
		super("^_^友谊牌^_^");
		this.buffer = buffer;
		this.cardMax = cardMax;
		cardNumber = new int[cardMax];
		for (int i = 0; i < cardNumber.length; i++) {// 初始化牌
			cardNumber[i] = i;
		}
		setBounds(800, 200, 400, 300);
		setDefaultCloseOperation(EXIT_ON_CLOSE);
		setVisible(true);
		text_area = new JTextArea();
		text_area.setSize(100, 300);
		text_area.setEditable(false);
		text_area.setLineWrap(true);
		pnl = new JPanel();
		pnl.setSize(200, 300);
		pnl.setLayout(new FlowLayout(FlowLayout.LEFT));
		getContentPane().add(pnl);
		getContentPane().add(new JScrollPane(text_area),BorderLayout.EAST);

		Thread t = new Thread(this);
		t.setPriority(Thread.MAX_PRIORITY);
		t.start();
	}

	public int[] shuffle(int[] cleancard) {
		if(cleancard==null||cleancard.length==0){
			return null;
		}
		int[] mycleancard = new int[cleancard.length];
		for (int i = 0; i < mycleancard.length; i++) {
			mycleancard[i] = cleancard[i];
		}
		int temp = 0, rand;
		for (int i = 0; i < mycleancard.length; i++) {// 第i个的元素与第rand个的元素 交换
			rand = (int) (Math.random() * 100) % cardMax;// 交换位置,错序
			temp = mycleancard[rand];
			mycleancard[rand] = mycleancard[i];
			mycleancard[i] = temp;
		}
		return mycleancard;
	}

	@Override
	public void run() {
		int[] mycard = shuffle(cardNumber);
		for (int i = 0; i < mycard.length; i++) {
			buffer.put(mycard[i]);
		}
		for (int i = 0; i < 4; i++) {// 使4个接收线程关闭
			buffer.put(-1);
		}
	}

}

class ReceiveCardThread extends JFrame implements Runnable, ActionListener {
	private CardBuffer buffer;
	public int order;
	private Color[] colors;
	private JPanel pnl;
	public JButton[] btns;
	private int count = 0;
	SendCardThread sendcardthread;
	public boolean isChange;

	public ReceiveCardThread(SendCardThread sendcardthread,CardBuffer buffer, int order, String title, int x,
			int y) {
		super(title);
		setLocation(x, y);
		setSize(220, 230);
		setDefaultCloseOperation(EXIT_ON_CLOSE);
		this.sendcardthread = sendcardthread;
		this.buffer = buffer;
		this.order = order;
		this.buffer = buffer;
		pnl = new JPanel();
		pnl.setLayout(new FlowLayout(FlowLayout.LEFT));
		pnl.setBackground(Color.white);
		getContentPane().add(pnl);
		colors  = new Color[] {Color.LIGHT_GRAY,Color.RED,Color.GRAY,Color.pink};
		btns = new JButton[13];
		for (int i = 0; i < 13; i++) {
			btns[i] = new JButton();
			btns[i].addActionListener(this);
		}

		setVisible(true);
		new Thread(this).start();
	}

	@Override
	public void run() {
		synchronized (this) {
			while (true) {
				int value = buffer.get(order);
				if (value == -1) {
					count = 0;
					return;
				}
				btns[count].setBackground(colors[value/13]);
				if (value % 13 == 0) {
					btns[count].setText(String.format("%4d", 13));
				} if(value % 13 >=10){
					btns[count].setText(String.format("%4d", value%13));
				}else {
					btns[count].setText(" "+String.format("%4d", value%13));
				}
				pnl.add(btns[count]);
				count++;
			}
		}
	}

	@Override
	public void actionPerformed(ActionEvent e) {
		for (int i = 0; i < 13; i++) {
			if(e.getSource() == btns[i]){
				String str = btns[i].getText();
				sendcardthread.text_area.append(str);
				JButton btn = new JButton();
				btn.setBackground(btns[i].getBackground());
				btn.setText(btns[i].getText());
				sendcardthread.pnl.add(btn);
				if(isChange){
					sendcardthread.setSize( 401, 300);
					isChange = !isChange;
				}else{
					sendcardthread.setSize( 402, 300);
					isChange = !isChange;
				}
			}
		}
	}

}

时间: 2024-10-14 07:14:21

发牌程序(二)的相关文章

妞一个斗地主发牌程序!!!

学习java三个星期,利用所学的知识做了一个三人斗地主发牌程序,闲话少叙,上代码 1 import java.util.ArrayList; 2 import java.util.Collections; 3 import java.util.List; 4 5 /** 6 * 三人斗地主程序 功能:将一副牌随机分发给地主(20张牌),农民A(17张牌),农民B (17张牌) 7 * 步骤:1.洗牌阶段:将54张牌储存到ArraryList 容器中(批量储存,for循环) 8 * 2.发牌阶段:

win32SDK的hello,world程序(二)

接上篇,原生的控件都不太好看,所以决定自己画一个,稍微处理下消息就能用了.不过,美化这东西是需要天赋的.即使技术再好,没有对UI布局调整和良好的审美能力,做出来的东西还是很挫. 主要把消息逻辑和画的过程写出来: LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { static bool b; switch (message) /* handle the message

phpcms程序二次开发记录

1. phpcms/base.php 中的 pc_base 类 静态类,主要加载各个文件使用.2. pc_base 中 load_sys_func 等带 sys的函数,基本都是加载 lib下文件. func加载functions下: class 加载 class下3. pc_base 中 函数一般第一个参数为文件名,第二个参数为路径,第3个参数有一般为:加载类是否实体化4. pc_base 中 load_app开头则为加载modules下的 functions和class等5. 网站开始入口控制

第十章 数组与集合 发牌程序 实例代码

解决方案目录: Suit.cs四种花色 namespace Cards { enum Suit { Clubs, Diamonds, Hearts, Spades } } Value.cs扑克牌的13中面值 namespace Cards { enum Value { Two, Three, Four, Five, Six, Seven, Eight, Nine, Ten, Jack, Queen, King, Ace } } Pack.cs发牌程序核心类 namespace Cards { u

房地产—客户关系管理系统CRM|软件开发|软件外包|程序二次开发

房地产—客户关系管理系统CRM|软件开发|软件外包|程序二次开发 主要:CRM管理,合同管理,绩效管理 1.CRM管理:新增客户,我的资源,公共资源,客户跟进,待审批客户,报备资源,审核释放,预约到访. 2.合同管理:查询合同,新增合同. 3.绩效管理:新增考核指标,考核进度跟踪,指标进度完成. 为了帮助地产企业秉承专业.人本精神,将客户服务工作持续贯彻于房地产开发的全过程,在产品策划阶段和工程管理阶段,预见性的提供客户需求的产品,将客户服务前置:在销售和售后服务阶段,预见性的为客户提供人性化的

小程序二维码生成接口API

获取小程序码 我们推荐生成并使用小程序码,它具有更好的辨识度.目前有两个接口可以生成小程序码,开发者可以根据自己的需要选择合适的接口. 接口A: 适用于需要的码数量较少的业务场景 接口地址: https://api.weixin.qq.com/wxa/getwxacode?access_token=ACCESS_TOKEN 获取 access_token 详见文档 POST 参数说明 注意:通过该接口生成的小程序码,永久有效,数量限制见文末说明,请谨慎使用.用户扫描该码进入小程序后,将直接进入

谷歌app二次验证码与微信小程序二次验证码对比实测

下面我就跟大家实测一下关于两款验证码的使用对比 NO.1:下载安装 谷歌二次验证码下载方式如下: 1.通过扫描交易所中二维码(目前所有交易所中都是提供下载二维码的) 2.手机应用商店搜索"Google Authenticator"进行下载 微信小程序下载方式如下: 1.进入微信直接搜索"二次验证码"即可 1.谷歌需要去下载app(费流量,有wifi和土豪忽略),微信不需要,直接使用! 2.搜索方面谷歌需要一连串的英文字母,比较复杂这个对我而言就比较难接受了(我是英语

PHP生成小程序二维码

/** * [生成小程序二维码] * @return [type] [description] */ public function makeMiniQrcode_do() { begin: $id = input('id');// 获取token $ACCESS_TOKEN = $this->getAccesstoken(); // 准备进入小程序的参数 $param = json_encode(array("path" => "pages/shop/shop?

C语言的随机发牌程序(红桃、黑桃、梅花、方块)

做一个随机发牌的C语言程序,供大家学习,思考. 未做任何注释,有测试时候留下的一些输出语句,一遍方便测试. /* author:nunu qq:398269786 */ #include<stdio.h> #include<stdlib.h> #include<time.h> int main() { int a[60]; int b[60]; int w = 0; int wi,wj,wii; int i,j,index,x=0,m; for(i=0;i<54;