相信大家會有這樣的需求,一個javabean內(nèi)有多個變量,每次改變都需要獲取到他們的狀態(tài),一般我們想到的可能是用接口回調(diào)的方法去監(jiān)聽變量的改變,一個javabean還好處理,那如果有很多呢,會使代碼顯得很臃腫且不好擴展,所以這里有個很好方法來處理以上需求。
在JavaBean的設計中,按照屬性的不同作用又細分為四類:單值屬性、索引屬性、關聯(lián)屬性、限制屬性。關聯(lián)屬性,也稱之為綁定屬性。綁定屬性會在屬性值發(fā)生變化時,通知所有相關的監(jiān)聽器。
先介紹幾個api吧
類PropertyChangeSupport
-
addPropertyChangeListener(PropertyChangeListener listener)
顧名思義,添加對bean的監(jiān)聽。 -
removePropertyChangeListener(PropertyChangeListener listener)
移除監(jiān)聽。 -
firePropertyChange(String propertyName, int oldValue, int newValue)
添加對bean內(nèi)某個變量的監(jiān)聽,第一個參數(shù)最好是變量名,第二個是變量改變前的值,第二個是變量改變后的值
類PropertyChangeEvent
https://docs.oracle.com/javase/7/docs/api/java/beans/PropertyChangeEvent.html
- getPropertyName()
獲取發(fā)生改變的變量名。 - getSource()
獲取改變的bean對象 - getOldValue()
獲取發(fā)生改變的變量的舊值。 - getNewValue()
獲取發(fā)生改變的變量的新值。
ok,不多說,上代碼
javabean類
public class DeviceInfo {
private static DeviceInfo deviceInfo;
public static DeviceInfo getInstance() {
if (deviceInfo == null) {
deviceInfo = new DeviceInfo();
}
return deviceInfo;
}
private PropertyChangeSupport changeSupport = new PropertyChangeSupport(this);
public String getDeviceName() {
return mDeviceName;
}
public void setDeviceName(String deviceName) {
String oldValue = mDeviceName;
this.mDeviceName = deviceName;
changeSupport.firePropertyChange("deviceName", oldValue, deviceName);
}
public String getDeviceStatus() {
return mDeviceStatus;
}
public void setDeviceStatus(String deviceStatus) {
String oldValue = mDeviceStatus;
this.mDeviceStatus = deviceStatus;
changeSupport.firePropertyChange("deviceStatus", oldValue, deviceStatus);
}
private String mDeviceName;
private String mDeviceStatus;
public void addPropertyChangeListener(PropertyChangeListener listener) {
changeSupport.addPropertyChangeListener(listener);
}
public void removePropertyChangeListener(PropertyChangeListener listener) {
changeSupport.removePropertyChangeListener(listener);
}
}
監(jiān)聽類
public class MainActivity extends AppCompatActivity implements PropertyChangeListener{
private static final String TAG = "MainActivity";
private EditText deviceName;
private EditText deviceStatus;
private Button change;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
deviceName = (EditText) findViewById(R.id.et_deviceName);
deviceStatus = (EditText) findViewById(R.id.et_deviceStatus);
change = (Button) findViewById(R.id.bt_change);
change.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String device_name = deviceName.getText().toString().trim();
String device_status = deviceStatus.getText().toString().trim();
DeviceInfo.getInstance().setDeviceName(device_name);
DeviceInfo.getInstance().setDeviceStatus(device_status);
}
});
DeviceInfo.getInstance().addPropertyChangeListener(this);
}
@Override
public void propertyChange(PropertyChangeEvent propertyChangeEvent) {
Log.d(TAG,"Source:"+propertyChangeEvent.getSource());
Log.d(TAG,"PropertyName:"+propertyChangeEvent.getPropertyName());
Log.d(TAG,"OldValue:"+propertyChangeEvent.getOldValue());
Log.d(TAG,"NewValue:"+propertyChangeEvent.getNewValue().toString());
Log.d(TAG,"---------------------------------------------------");
}
}
好的,操作后的打印值:
初次賦值時oldvalue是null,記得判空。
CD353Z5$MPBLOB2KKFR({_V.png
U})8$O$L10D95R{Q@LDIY)9.png
恩,好啦,特別是當bean很多的時候特別好用,用propertyChangeEvent.getSource()就能區(qū)分是哪個bean了。