`

玩转Android---事件监听篇---第2篇

阅读更多

事件监听篇---第二篇

 

下面是各种常用控件的事件监听的使用

①EditText(编辑框)的事件监听---OnKeyListener

②RadioGroup、RadioButton(单选按钮)的事件监听---OnCheckedChangeListener

③CheckBox(多选按钮)的事件监听---OnCheckedChangeListener

④Spinner(下拉列表)的事件监听---OnItemSelectedListener

⑤Menu(菜单)的事件处理---onMenuItemSelected

⑥Dialog(对话框)的事件监听---DialogInterface.OnClickListener()

 

第一个例子:EditText的事件监听

 

package org.hualang.eventtest2;

import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;

public class EventTest2 extends Activity {
    /** Called when the activity is first created. */
	private TextView mytext;
	private EditText edittext;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        mytext = (TextView)findViewById(R.id.mytext);
        edittext = (EditText)findViewById(R.id.edittext);
        /**
         * 设置当EditText为空,则提示“请输入账号”
         * 在配置文件main.xml中可以用android:hint="请输入账号"来实现
         */
        edittext.setHint("请输入账号");
        //下面为EditText事件监听
        edittext.setOnKeyListener(new EditText.OnKeyListener()
        {

			@Override
			public boolean onKey(View arg0, int arg1, KeyEvent arg2) {
				//得到文字,显示在TextView中
				mytext.setText("内容:"+edittext.getText().toString());
				return false;
			}
        	
        });
    }
}

 main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:id="@+id/mytext"
    />
<EditText
	android:id="@+id/edittext"
	android:layout_width="fill_parent"
	android:layout_height="wrap_content"
	android:textSize="10pt"
/>
</LinearLayout>

 

运行结果如下:



 

 

 

第二个例子:单选按钮的事件监听处理

package org.hualang.eventtest;

import android.app.Activity;
import android.os.Bundle;
import android.view.Gravity;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.Toast;

public class EventTest3 extends Activity {
    /** Called when the activity is first created. */
	private RadioGroup group;
	private RadioButton radio1,radio2,radio3,radio4;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        group = (RadioGroup)findViewById(R.id.radiogroup1);
        radio1 = (RadioButton)findViewById(R.id.button1);
        radio2 = (RadioButton)findViewById(R.id.button2);
        radio3 = (RadioButton)findViewById(R.id.button3);
        radio4 = (RadioButton)findViewById(R.id.button4);
        
        group.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
			
			@Override
			public void onCheckedChanged(RadioGroup group, int checkedId) {
				// TODO Auto-generated method stub
				if (checkedId == radio2.getId())
				{
					showMessage("正确答案:" + radio2.getText()+",恭喜你,答对了");
				}
				else
				{
					showMessage("对不起,虽然很多,但不是公认的最多");
				}
			}
		});
    }
    public void showMessage(String str)
    {
    	Toast toast = Toast.makeText(this, str, Toast.LENGTH_SHORT);
    	toast.setGravity(Gravity.TOP, 0, 220);
    	toast.show();
    }
}

 main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
	<TextView
		android:id="@+id/mytextview"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="哪个城市的美女最多?"
	/>
	<RadioGroup
		android:id="@+id/radiogroup1"
		android:layout_width="wrap_content"
		android:layout_height="wrap_content"
		android:orientation="vertical"
	>
		<RadioButton
			android:id="@+id/button1"
			android:layout_width="wrap_content"
			android:layout_height="wrap_content"
			android:text="杭州"
		/>
		<RadioButton
			android:id="@+id/button2"
			android:layout_width="wrap_content"
			android:layout_height="wrap_content"
			android:text="重庆"
		/>
		<RadioButton
			android:id="@+id/button3"
			android:layout_width="wrap_content"
			android:layout_height="wrap_content"
			android:text="成都"
		/>
		<RadioButton
			android:id="@+id/button4"
			android:layout_width="wrap_content"
			android:layout_height="wrap_content"
			android:text="香港"
		/>
	</RadioGroup>
</LinearLayout>

 

运行结果如下:



 

第三个例子:复选框的事件处理

package org.hualang.eventtest4;

import android.app.Activity;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.CompoundButton.OnCheckedChangeListener;
import android.widget.Toast;

public class EventTest4 extends Activity {
    /** Called when the activity is first created. */
	private CheckBox ch1,ch2,ch3,ch4,ch5;
	private Button mybutton;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        mybutton = (Button)findViewById(R.id.mybutton);
        ch1 = (CheckBox)findViewById(R.id.check1);
        ch2 = (CheckBox)findViewById(R.id.check2);
        ch3 = (CheckBox)findViewById(R.id.check3);
        ch4 = (CheckBox)findViewById(R.id.check4);
        ch5 = (CheckBox)findViewById(R.id.check5);
        
        ch1.setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener()
        {

			@Override
			public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
				// TODO Auto-generated method stub
				if(ch1.isChecked())
				{
					showMessage("你选择了"+ch1.getText());
				}
			}
        	
        });
        ch2.setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener()
        {

			@Override
			public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
				// TODO Auto-generated method stub
				if(ch3.isChecked())
				{
					showMessage("你选择了"+ch2.getText());
				}
			}
        	
        });
        ch3.setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener()
        {

			@Override
			public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
				// TODO Auto-generated method stub
				if(ch3.isChecked())
				{
					showMessage("你选择了"+ch3.getText());
				}
			}
        	
        });
        ch4.setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener()
        {

			@Override
			public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
				// TODO Auto-generated method stub
				if(ch4.isChecked())
				{
					showMessage("你选择了"+ch4.getText());
				}
			}
        	
        });
        ch5.setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener()
        {

			@Override
			public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
				// TODO Auto-generated method stub
				if(ch5.isChecked())
				{
					showMessage("你选择了"+ch5.getText());
				}
			}
        	
        });
        
        mybutton.setOnClickListener(new Button.OnClickListener()
        {

			@Override
			public void onClick(View arg0) {
				// TODO Auto-generated method stub
				int num = 0;
				if(ch1.isChecked())
				{
					num++;
				}
				if(ch2.isChecked())
				{
					num++;
				}
				if(ch3.isChecked())
				{
					num++;
				}
				if(ch4.isChecked())
				{
					num++;
				}
				if(ch5.isChecked())
				{
					num++;
				}
				
				showMessage("谢谢参与,您一共选择了"+num+"项");
				
			}
        	
        });
    }
    

    
    public void showMessage(String str)
    {
    	Toast toast = Toast.makeText(this, str, Toast.LENGTH_SHORT);
    	toast.setGravity(Gravity.TOP, 0, 220);
    	toast.show();
    }
}

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
	<TextView  
	    android:layout_width="fill_parent" 
	    android:layout_height="wrap_content" 
	    android:text="你喜欢哪些智能手机系统"
	    />
	<CheckBox
		android:id="@+id/check1"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="苹果 ios"
	/>
	<CheckBox
		android:id="@+id/check2"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="谷歌 Android"
	/>
	<CheckBox
		android:id="@+id/check3"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="RIM BlackBerry"
	/>
	<CheckBox
		android:id="@+id/check4"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="微软 Windows phone 7"
	/>
	<CheckBox
		android:id="@+id/check5"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="诺基亚 symbian"
	/>
	<Button
		android:id="@+id/mybutton"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:text="确定"
	/>

</LinearLayout>

 

运行结果:



 

第四个例子:Spinner下拉菜单的事件处理

package org.hualang.eventtest5;

import android.app.Activity;   
import android.os.Bundle;   
import android.view.View;   
import android.widget.AdapterView;   
import android.widget.ArrayAdapter;   
import android.widget.Spinner;   
import android.widget.TextView;   
  
public class EventTest5 extends Activity {   
    /** Called when the activity is first created. */  
    private static final String[] citys={"杭州","北京","成都","大连","深圳","南京"};   
    private TextView text;   
    private Spinner spinner;   
    private ArrayAdapter<String> adapter;   
    @Override  
    public void onCreate(Bundle savedInstanceState) {   
        super.onCreate(savedInstanceState);   
        setContentView(R.layout.main);   
        text=(TextView)findViewById(R.id.text);   
        spinner=(Spinner)findViewById(R.id.spinner);   
           
        //将可选内容与ArrayAdapter连接   
        adapter=new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item,citys);   
        //设置下拉列表风格   
        adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);   
        //将adapter添加到spinner中   
        spinner.setAdapter(adapter);   
        //添加Spinner事件监听   
        spinner.setOnItemSelectedListener(new Spinner.OnItemSelectedListener()   
        {   
  
            @Override  
            public void onItemSelected(AdapterView<?> arg0, View arg1,   
                    int arg2, long arg3) {   
                // TODO Auto-generated method stub   
                text.setText("你所在的城市是:"+citys[arg2]);   
                //设置显示当前选择的项   
                arg0.setVisibility(View.VISIBLE);   
            }   
  
            @Override  
            public void onNothingSelected(AdapterView<?> arg0) {   
                // TODO Auto-generated method stub   
                   
            }   
               
        });   
    }   
}  

 

main.xml

<?xml version="1.0" encoding="utf-8"?>   
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >   
<TextView     
    android:id="@+id/text"  
    android:layout_width="fill_parent"    
    android:layout_height="wrap_content"    
    android:text="您所在的城市"  
    />   
<Spinner   
    android:id="@+id/spinner"  
    android:layout_width="wrap_content"  
    android:layout_height="wrap_content"  
    android:layout_centerHorizontal="true"  
/>   
</LinearLayout>

 

运行结果如下:



 

 

 

第五个例子:Menu(菜单)的事件处理

package org.hualang.eventtest6;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.Toast;

public class EventTest6 extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// TODO Auto-generated method stub
		MenuInflater inflater = getMenuInflater();
		//设置menu界面为res/menu/menu.xml
		inflater.inflate(R.menu.menu, menu);
		return true;
	}

	@Override
	public boolean onMenuItemSelected(int featureId, MenuItem item) {
		//得到当前选中的MenuItem的ID
		int itemId = item.getItemId();
		switch(itemId)
		{
		case R.id.apple:
			Toast toast = Toast.makeText(this, "这是苹果", Toast.LENGTH_SHORT);
			toast.show();
			break;
		case R.id.banana:
			Toast toast2 = Toast.makeText(this, "这是香蕉", Toast.LENGTH_SHORT);
			toast2.show();
			break;
		case R.id.exit:
			EventTest6.this.finish();
			break;
		}
		return true;
	}
    
    
}

 res/menu/menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
	<item android:id="@+id/apple"
		android:title="苹果"
	/>
	<item android:id="@+id/banana"
		android:title="香蕉"
		/>
	<item android:id="@+id/exit"
		android:title="退出"
		/>
</menu>

 

运行结果如下:



 

 

 

第六个例子:对话框的事件处理

package org.hualang.dialog;

import android.app.Activity;
import android.app.AlertDialog;
import android.app.Dialog;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;

public class MainActivity extends Activity {
    /** Called when the activity is first created. */
	ProgressDialog myDialog;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        Dialog dialog = new AlertDialog.Builder(MainActivity.this)
        .setTitle("登录提示")
        .setMessage("这里需要登录")
        .setPositiveButton("确定", new DialogInterface.OnClickListener() {
			
			@Override
			public void onClick(DialogInterface dialog, int which) {
				// TODO Auto-generated method stub
				LayoutInflater factory = LayoutInflater.from(MainActivity.this);
				final View DialogView = factory.inflate(R.layout.dialog, null);
				AlertDialog dlg = new AlertDialog.Builder(MainActivity.this)
				.setTitle("登录框")
				.setView(DialogView)
				.setPositiveButton("确定", new DialogInterface.OnClickListener() {
					
					@Override
					public void onClick(DialogInterface dialog, int whichButton) {
						// TODO Auto-generated method stub
						myDialog = ProgressDialog.show(MainActivity.this, "请等待...", "正在为你登录", true);
						new Thread()
						{
							public void run()
							{
								try
								{
									sleep(3000);
								}catch(Exception e)
								{
									e.printStackTrace();
								}finally
								{
									myDialog.dismiss();
								}
							}
						}.start();
					}
				}).setNegativeButton("取消",
						new DialogInterface.OnClickListener() {
							
							@Override
							public void onClick(DialogInterface dialog, int which) {
								// TODO Auto-generated method stub
								MainActivity.this.finish();
							}
						}).create();
				dlg.show();
			}
		}).setNeutralButton("退出", new DialogInterface.OnClickListener() {
			
			@Override
			public void onClick(DialogInterface dialog, int which) {
				// TODO Auto-generated method stub
				MainActivity.this.finish();
			}
		}).create();
        dialog.show();
    
    }
}

 

res/layout/dialog.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
	<TextView  
		android:id="@+id/username"
	    android:layout_width="wrap_content" 
	    android:layout_height="wrap_content"
	    android:layout_marginLeft="20dip"
	    android:layout_marginRight="20dip" 
	    android:text="账号"
	    android:gravity="left"
	    android:textAppearance="?android:attr/textAppearanceMedium"
    />
  	<EditText
  		android:id="@+id/myusername"
  		android:layout_height="wrap_content"
  		android:layout_width="fill_parent"
  		android:layout_marginLeft="20dip"
  		android:layout_marginRight="20dip"
  		android:scrollHorizontally="true"
  		android:autoText="false"
  		android:capitalize="none"
  		android:gravity="fill_horizontal"
  		android:textAppearance="?android:attr/textAppearanceMedium"
  	/>
  	<TextView
  		android:id="@+id/password"
  		android:layout_width="fill_parent"
  		android:layout_height="wrap_content"
  		android:layout_marginLeft="20dip"
  		android:layout_marginRight="20dip"
  		android:text="密码"
  		android:gravity="left"
  		android:textAppearance="?android:attr/textAppearanceMedium"
  	/>
  	<EditText
  		android:id="@+id/mypassword"
  		android:layout_width="fill_parent"
  		android:layout_height="wrap_content"
  		android:layout_marginLeft="20dip"
  		android:layout_marginRight="20dip"
  		android:scrollHorizontally="true"
  		android:autoText="false"
  		android:capitalize="none"
  		android:gravity="fill_horizontal"
  		android:password="true"
  	/>
</LinearLayout>

 

 

运行结果:



 

 

 

 

  • 大小: 9.6 KB
  • 大小: 9.2 KB
  • 大小: 13.6 KB
  • 大小: 17.8 KB
  • 大小: 8.8 KB
  • 大小: 16.1 KB
  • 大小: 9 KB
  • 大小: 9.9 KB
  • 大小: 8.8 KB
  • 大小: 13.8 KB
  • 大小: 16.4 KB
  • 大小: 12.1 KB
分享到:
评论
7 楼 jiazi020390 2011-09-08  
很好!!~~
6 楼 sxd_0524 2011-08-18  
我喜欢。。
5 楼 xianyunxiaoyao 2011-07-05  
不管是哪里的,学到了才是真理!  
4 楼 wangguangji 2011-06-01  
怎么发现你的这些东西都是一个视频里面的例子啊呢
3 楼 一点寒意 2011-06-01  
都是一些界面上的东西,不过楼主精神可嘉。
2 楼 kkvsyy 2011-06-01  
这个东西 好 
1 楼 yabar 2011-05-31  

相关推荐

    玩转Android---2D图形及动画---Frame动画

    这篇博文"玩转Android---2D图形及动画---Frame动画"显然会深入探讨如何在Android平台上创建和管理帧动画。帧动画是一种将一系列静态图像连续播放以产生动态效果的技术,常见于游戏和应用程序中的过渡效果。 首先,...

    android wheel menu

    综上所述,Android Wheel Menu是一种在Android应用中创建独特交互体验的工具,它能够帮助开发者设计出引人注目的菜单系统,提高应用的可玩性和用户满意度。通过合理的自定义和扩展,开发者可以打造出符合自己应用...

    Android控件操作-二十四章经 - v1.01

    第二章“EditText探秘”探讨了用户输入文本的EditText控件,涵盖了输入限制、提示文字、光标控制等高级用法,帮助开发者创建交互式的输入界面。 第三章“交互之王Button控件”详细讲解了按钮Button的使用,包括点击...

    Android面试算法题

    ### Android面试算法题知识点解析 #### 一、基础算法题:找出未放入数组中的两个数 **题目背景:** 在Android开发过程中,处理数组是非常常见的需求之一。此题旨在考察应聘者对基本数据结构(如数组)的理解以及...

    cocos2d-x权威指南完整版

    - **编写事件监听器**:处理用户输入,如触摸屏事件。 #### 三、cocos2d-x进阶技术 **3.1 物理引擎集成** - **Box2D集成**:将Box2D物理引擎集成到cocos2d-x项目中,模拟真实的物理效果。 - **碰撞检测与响应**:...

    【经典Android游戏源码15】Android 涂鸦跳跃源码

    2. **触摸事件处理**:Android系统提供了触摸事件API,用于监听用户的触摸操作。涂鸦跳跃的源码会解析这些事件,将玩家的滑动和点击转化为游戏中角色的跳跃、左右移动等动作。 3. **2D图形绘制**:Android提供了...

    Cocos2d-x 3.1.1 微信打飞机源码

    Cocos2d-x提供了事件监听和分发机制,方便开发者处理用户输入。 4. **物理引擎**:虽然Cocos2d-x本身不包含完整的物理引擎,但它可以与Box2D等第三方物理引擎集成,为游戏添加真实的物理行为。 5. **音频支持**:...

    PlumberGame-AndroidApp

    例如,通过Java类来定义游戏元素(如管道、水源、目标点),使用事件监听处理用户的触摸操作,通过计时器实现动态效果。 3. **游戏逻辑实现**: 在"PlumberGame"中,游戏的核心逻辑是判断管道连接是否正确,这需要...

    Android游戏捕鱼达人代码

    Android的触摸事件处理机制是关键,需要监听ACTION_DOWN、ACTION_MOVE和ACTION_UP等事件,根据用户手势控制子弹的发射方向和力度。同时,游戏界面需要提供友好的反馈,如点击音效、视觉反馈等。 4. **物理引擎**: ...

    基于Android的智能课表的设计与实现.pdf

    用户第一次使用程序会转到设置界面,对一些基本的选项进行配置,如本学期的第一周从哪天开始,是否开启提醒功能,是否开启学霸功能等;设置完成转到添加课表界面,用户可以添加课表信息等操作,添加课表时要操作...

    Android项目源码仿微信登录注册聊天换肤二维码扫描.zip

    可以脸红的说,基本上所有功能实现都放在第一个eric_jqm_chat包里了,第二个Service包主要放与于后台服务相关的包,但后来这些服务我也都没有启用,后面的四个Zxing包就是实现二维码扫描的包,具体如何实现我的博客...

    android游戏

    【描述】:这个压缩包包含了一个Android游戏的源代码,游戏的核心玩法是通过利用设备的重力感应功能来控制一个小球,目的是避开怪物的追逐。游戏内还提供了一份PPT开发说明,对于初学者来说,这是一份宝贵的资源,...

    calendar-mulselect.zip

    在Android开发中,日历(Calendar)功能是一个常见的需求,特别是在多选模式下,用户可能需要选择多个日期,如在事件安排、会议预定或者行程规划等场景。"calendar-mulselect.zip" 文件很可能包含了实现这一功能的...

    简单的天气查询

    在压缩包子文件的文件名称列表中,“项目3:第二组”可能代表这是一个学习项目的一部分,可能是某个课程或工作坊的作业,其中“项目3”可能指的是系列项目中的第三个,而“第二组”可能指的是参与该项目的团队或个人...

    unity3d 麻将

    - **输入处理**:Unity3D支持鼠标、键盘和触摸屏等多种输入方式,开发者需要编写事件监听器,以便玩家通过点击或拖动操作麻将牌。 - **UI设计**:游戏界面包括麻将桌、牌堆、玩家手牌等元素,通常使用Unity的UI...

    richer单机完毕源码

    《richer大富翁游戏单机完毕源码》是一款基于Cocos2dx框架开发的桌面游戏,它将经典的“大富翁”玩法移植到了数字平台上。Cocos2dx是一款广泛使用的开源游戏开发库,它支持多平台,包括iOS、Android、Windows等,...

    安卓开发学习日记第四天_会爬就会跑_莫韵乐的欢乐日记

    在安卓开发的学习过程中,第四天的主题是"会爬就会跑",这标志着开发者已经掌握了基础,准备迈向更复杂的阶段。这个阶段的任务是一个基于小时候玩的关灯游戏的小应用开发。以下将详细介绍在这个过程中涉及的关键知识...

    JAVA上百实例源码以及开源项目源代码

    此时此景,笔者只专注Android、Iphone等移动平台开发,看着这些源码心中有万分感慨,写此文章纪念那时那景! Java 源码包 Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这...

Global site tag (gtag.js) - Google Analytics