亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android手機(jī)通過藍(lán)牙連接佳博打印機(jī)的實例代碼

 更新時間:2016年11月07日 17:22:23   作者:yun1  
這篇文章主要介紹了Android手機(jī)通過藍(lán)牙連接佳博打印機(jī)的實例代碼,非常不錯具有參考借鑒價值,需要的朋友可以參考下

所使用的打印機(jī)為佳博打印機(jī),支持藍(lán)牙、wifi、usb我所使用的是通過藍(lán)牙來連接。

在網(wǎng)上找到一個佳博官方針對安卓開發(fā)的App源碼,但是各種的跳轉(zhuǎn),沒有看太懂,所以又去問度娘,找到了一個不錯的文章

Android對于藍(lán)牙開發(fā)從2.0版本的sdk才開始支持,而且模擬器不支持,測試至少需要兩部手機(jī),所以制約了很多技術(shù)人員的開發(fā)。

1. 首先,要操作藍(lán)牙,先要在AndroidManifest.xml里加入權(quán)限

// 管理藍(lán)牙設(shè)備的權(quán)限 
<uses-permissionandroid:name="android.permission.BLUETOOTH_ADMIN" />
// 使用藍(lán)牙設(shè)備的權(quán)限 
<uses-permissionandroid:name="android.permission.BLUETOOTH" />

2.打開藍(lán)牙

獲得藍(lán)牙適配器(android.bluetooth.BluetoothAdapter),檢查該設(shè)備是否支持藍(lán)牙,如果支持,就打開藍(lán)牙。

// 檢查設(shè)備是否支持藍(lán)牙 
adapter = BluetoothAdapter.getDefaultAdapter(); 
if (adapter == null) 
{ 
// 設(shè)備不支持藍(lán)牙 
} 
// 打開藍(lán)牙 
if (!adapter.isEnabled()) 
{ 
Intent intent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE); 
// 設(shè)置藍(lán)牙可見性,最多300秒 
intent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION,300);
context.startActivity(intent); 
}

3.獲取已配對的藍(lán)牙設(shè)備(android.bluetooth.BluetoothDevice)

首次連接某藍(lán)牙設(shè)備需要先配對,一旦配對成功,該設(shè)備的信息會被保存,以后連接時無需再配對,所以已配對的設(shè)備不一定是能連接的。

BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter(); 
Set<BluetoothDevice> devices = adapter.getBondedDevices(); 
for(int i=0; i<devices.size(); i++) 
{ 
BluetoothDevice device =
BluetoothDevice)devices.iterator().next(); 
System.out.println(device.getName()); 
} 

4.搜索周圍的藍(lán)牙設(shè)備

適配器搜索藍(lán)牙設(shè)備后將結(jié)果以廣播形式傳出去,所以需要自定義一個繼承廣播的類,在onReceive方法中獲得并處理藍(lán)牙設(shè)備的搜索結(jié)果。

// 設(shè)置廣播信息過濾 
IntentFilter intentFilter = new IntentFilter(); 
intentFilter.addAction(BluetoothDevice.ACTION_FOUND); 
intentFilter.addAction(BluetoothDevice.ACTION_BOND_STATE_CHANGED); 
intentFilter.addAction(BluetoothAdapter.ACTION_SCAN_MODE_CHANGED); 
intentFilter.addAction(BluetoothAdapter.ACTION_STATE_CHANGED); 
// 注冊廣播接收器,接收并處理搜索結(jié)果 
context.registerReceiver(receiver, intentFilter); 
// 尋找藍(lán)牙設(shè)備,android會將查找到的設(shè)備以廣播形式發(fā)出去 
adapter.startDiscovery(); 
自定義廣播類
private BroadcastReceiver receiver = new BroadcastReceiver() { 
@Override 
public void onReceive(Context context, Intent intent) { 
String action = intent.getAction(); 
if (BluetoothDevice.ACTION_FOUND.equals(action)) { 
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); 
System.out.println(device.getName()); 
} 
} 
}

5.藍(lán)牙設(shè)備的配對和狀態(tài)監(jiān)視

private BroadcastReceiver receiver = new BroadcastReceiver() { 
@Override 
public void onReceive(Context context, Intent intent) { 
String action = intent.getAction(); 
if (BluetoothDevice.ACTION_FOUND.equals(action)) { 
// 獲取查找到的藍(lán)牙設(shè)備 
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); 
System.out.println(device.getName()); 
// 如果查找到的設(shè)備符合要連接的設(shè)備,處理 
if (device.getName().equalsIgnoreCase(name)) { 
// 搜索藍(lán)牙設(shè)備的過程占用資源比較多,一旦找到需要連接的設(shè)備后需要及時關(guān)閉搜索 
adapter.cancelDiscovery(); 
// 獲取藍(lán)牙設(shè)備的連接狀態(tài) 
connectState = device.getBondState(); 
switch (connectState) { 
// 未配對 
case BluetoothDevice.BOND_NONE: 
// 配對 
try { 
Method createBondMethod = BluetoothDevice.class.getMethod("createBond"); 
createBondMethod.invoke(device); 
} catch (Exception e) { 
e.printStackTrace(); 
} 
break; 
// 已配對 
case BluetoothDevice.BOND_BONDED: 
try { 
// 連接 
connect(device); 
} catch (IOException e) { 
e.printStackTrace(); 
} 
break; 
} 
} 
} else if(BluetoothDevice.ACTION_BOND_STATE_CHANGED.equals(action)) { 
// 狀態(tài)改變的廣播 
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); 
if (device.getName().equalsIgnoreCase(name)) { 
connectState = device.getBondState(); 
switch (connectState) { 
case BluetoothDevice.BOND_NONE: 
break; 
case BluetoothDevice.BOND_BONDING: 
break; 
case BluetoothDevice.BOND_BONDED: 
try { 
// 連接 
connect(device); 
} catch (IOException e) { 
e.printStackTrace(); 
} 
break; 
} 
} 
} 
} 
}

6.藍(lán)牙設(shè)備的連接

private void connect(BluetoothDevice device) throws IOException { 
// 固定的UUID 
final String SPP_UUID = "00001101-0000-1000-8000-00805F9B34FB"; 
UUID uuid = UUID.fromString(SPP_UUID); 
BluetoothSocket socket = device.createRfcommSocketToServiceRecord(uuid); 
socket.connect(); 
} 
private void connect(BluetoothDevice device) throws IOException { 
// 固定的UUID 
final String SPP_UUID = "00001101-0000-1000-8000-00805F9B34FB"; 
UUID uuid = UUID.fromString(SPP_UUID); 
BluetoothSocket socket = device.createRfcommSocketToServiceRecord(uuid); 
socket.connect(); 
}

1.BluetoothAdapter 顧名思義,藍(lán)牙適配器,直到我們建立bluetoothSocket連接之前,都要不斷操作它

BluetoothAdapter里的方法很多,常用的有以下幾個:

cancelDiscovery() 根據(jù)字面意思,是取消發(fā)現(xiàn),也就是說當(dāng)我們正在搜索設(shè)備的時候調(diào)用這個方法將不再繼續(xù)搜索

disable()關(guān)閉藍(lán)牙

enable()打開藍(lán)牙,這個方法打開藍(lán)牙不會彈出提示,更多的時候我們需要問下用戶是否打開,一下這兩行代碼同樣是打開藍(lán)牙,不過會提示用戶:

Intemtenabler=new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);

startActivityForResult(enabler,reCode);//同startActivity(enabler);

getAddress()獲取本地藍(lán)牙地址

getDefaultAdapter()獲取默認(rèn)BluetoothAdapter,實際上,也只有這一種方法獲取BluetoothAdapter

getName()獲取本地藍(lán)牙名稱

getRemoteDevice(String address)根據(jù)藍(lán)牙地址獲取遠(yuǎn)程藍(lán)牙設(shè)備

getState()獲取本地藍(lán)牙適配器當(dāng)前狀態(tài)(感覺可能調(diào)試的時候更需要)

isDiscovering()判斷當(dāng)前是否正在查找設(shè)備,是返回true

isEnabled()判斷藍(lán)牙是否打開,已打開返回true,否則,返回false

listenUsingRfcommWithServiceRecord(String name,UUID uuid)根據(jù)名稱,UUID創(chuàng)建并返回BluetoothServerSocket,這是創(chuàng)建BluetoothSocket服務(wù)器端的第一步

startDiscovery()開始搜索,這是搜索的第一步

2.BluetoothDevice看名字就知道,這個類描述了一個藍(lán)牙設(shè)備

createRfcommSocketToServiceRecord(UUIDuuid)根據(jù)UUID創(chuàng)建并返回一個BluetoothSocket

這個方法也是我們獲取BluetoothDevice的目的——創(chuàng)建BluetoothSocket

這個類其他的方法,如getAddress(),getName(),同BluetoothAdapter

3.BluetoothServerSocket如果去除了Bluetooth相信大家一定再熟悉不過了,既然是Socket,方法就應(yīng)該都差不多,

這個類一種只有三個方法

兩個重載的accept(),accept(inttimeout)兩者的區(qū)別在于后面的方法指定了過時時間,需要注意的是,執(zhí)行這兩個方法的時候,直到接收到了客戶端的請求(或是過期之后),都會阻塞線程,應(yīng)該放在新線程里運行!

還有一點需要注意的是,這兩個方法都返回一個BluetoothSocket,最后的連接也是服務(wù)器端與客戶端的兩個BluetoothSocket的連接

close()這個就不用說了吧,翻譯一下——關(guān)閉!

4.BluetoothSocket,跟BluetoothServerSocket相對,是客戶端

一共5個方法,不出意外,都會用到

close(),關(guān)閉

connect()連接

getInptuStream()獲取輸入流

getOutputStream()獲取輸出流

getRemoteDevice()獲取遠(yuǎn)程設(shè)備,這里指的是獲取bluetoothSocket指定連接的那個遠(yuǎn)程藍(lán)牙設(shè)備

根據(jù)這篇文章只是更改了最后的藍(lán)牙連接部分(因為佳博打印機(jī)有自己的SDK,SDK中有自己的連接方法)將下載的DEMO中的gprintersdkv22.jar和xUtils-2.6.14.jar兩個包導(dǎo)入,之后的連接方法如下:

/**
*連接
*/
private voidconnect() {
intrel =0;
try{//使用端口1,4代表模式為藍(lán)牙模式,藍(lán)牙地址,最后默認(rèn)為0
rel = mGpService.openPort(1,4,adressData.get(loction),0);
}catch(RemoteException e) {
e.printStackTrace();
}
GpCom.ERROR_CODE r = GpCom.ERROR_CODE.values()[rel];
if(r != GpCom.ERROR_CODE.SUCCESS) {
if(r == GpCom.ERROR_CODE.DEVICE_ALREADY_OPEN) {
//開啟成功
}else{
UIUtils.showMessage(GpCom.getErrorText(r));
}
}else{
ProgressDialogUtil.dismiss(BuleToothActivity.this);
UIUtils.showMessage("失敗");
}
}

不要忘記的就是mGpService是佳博SDK的一個自己的服務(wù),要先獲取,并與Activity進(jìn)行綁定;

protected voidonCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_buletooth);
connection();
}
private voidconnection() {
conn=newPrinterServiceConnection();
Intent intent =newIntent(this, GpPrintService.class);
this.bindService(intent,conn, Context.BIND_AUTO_CREATE);// bindService
}
classPrinterServiceConnectionimplementsServiceConnection {
@Override
public void onServiceDisconnected(ComponentName name) {
mGpService=null;
}
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
mGpService= GpService.Stub.asInterface(service);
}
}

還要在清單文件中去配置服務(wù)

<service
android:name="com.gprinter.service.GpPrintService"
android:enabled="true"
android:exported="true"
android:label="GpPrintService">
<intent-filter>
<actionandroid:name="com.gprinter.aidl.GpPrintService"/>
</intent-filter>
</service>
<serviceandroid:name="com.gprinter.service.AllService">
</service>

做完這些之后就大功告成,可以連接到打印機(jī)了,不過還是不能打印,還要進(jìn)行一些打印的配置,由于我的項目的原因,連接和打印并沒有在同一個界面,所以繼續(xù)去研究佳博源碼,發(fā)現(xiàn)如果前面鏈接已經(jīng)成功的話,在另一個界面只需就行一個配置就可一直接打印打印也代碼如下:

public classPrintActivityextendsBaseActivityimplementsView.OnClickListener{
@Bind(R.id.print_print)
Buttonprint;
privateGpServicemGpService=null;
privatePrinterServiceConnectionconn=null;
private static final int MAIN_QUERY_PRINTER_STATUS=0xfe;
private static final int REQUEST_PRINT_LABEL=0xfd;
private static final int REQUEST_PRINT_RECEIPT=0xfc;
private int mTotalCopies=0;
@Override
protected void initHandler() {
handler=newHandler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
}
};
}
privateBroadcastReceivermBroadcastReceiver=newBroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
Log.d("TAG", action);
// GpCom.ACTION_DEVICE_REAL_STATUS 為廣播的IntentFilter
if(action.equals(GpCom.ACTION_DEVICE_REAL_STATUS)) {
//業(yè)務(wù)邏輯的請求碼,對應(yīng)哪里查詢做什么操作
intrequestCode = intent.getIntExtra(GpCom.EXTRA_PRINTER_REQUEST_CODE, -1);
//判斷請求碼,是則進(jìn)行業(yè)務(wù)操作
if(requestCode ==MAIN_QUERY_PRINTER_STATUS) {
intstatus = intent.getIntExtra(GpCom.EXTRA_PRINTER_REAL_STATUS,16);
String str;
if(status == GpCom.STATE_NO_ERR) {
str ="打印機(jī)正常";
}else{
str ="打印機(jī) ";
if((byte) (status & GpCom.STATE_OFFLINE) > 0) {
str +="脫機(jī)";
}
if((byte) (status & GpCom.STATE_PAPER_ERR) > 0) {
str +="缺紙";
}
if((byte) (status & GpCom.STATE_COVER_OPEN) > 0) {
str +="打印機(jī)開蓋";
}
if((byte) (status & GpCom.STATE_ERR_OCCURS) > 0) {
str +="打印機(jī)出錯";
}
if((byte) (status & GpCom.STATE_TIMES_OUT) > 0) {
str +="查詢超時";
}
}
Toast.makeText(getApplicationContext(),"打印機(jī):"+1+"狀態(tài):"+ str, Toast.LENGTH_SHORT)
.show();
}else if(requestCode ==REQUEST_PRINT_RECEIPT) {
intstatus = intent.getIntExtra(GpCom.EXTRA_PRINTER_REAL_STATUS,16);
if(status == GpCom.STATE_NO_ERR) {
sendReceipt();
}else{
Toast.makeText(PrintActivity.this,"query printer status error", Toast.LENGTH_SHORT).show();
}
}
}
}
};
@Override
protected void initTitle() {
mTitleTextMiddle.setText("打印");
}
private void connection() {
conn=newPrinterServiceConnection();
Intent intent =newIntent(this, GpPrintService.class);
this.bindService(intent,conn, Context.BIND_AUTO_CREATE);// bindService
}
classPrinterServiceConnectionimplementsServiceConnection {
@Override
public void onServiceDisconnected(ComponentName name) {
Log.i("ServiceConnection","onServiceDisconnected() called");
mGpService=null;
}
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
mGpService= GpService.Stub.asInterface(service);
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_print);
connection();
//注冊實時狀態(tài)查詢廣播
registerReceiver(mBroadcastReceiver,newIntentFilter(GpCom.ACTION_DEVICE_REAL_STATUS));
/**
*票據(jù)模式下,可注冊該廣播,在需要打印內(nèi)容的最后加入addQueryPrinterStatus(),在打印完成后會接收到
* action為GpCom.ACTION_DEVICE_STATUS的廣播,特別用于連續(xù)打印,
*可參照該sample中的sendReceiptWithResponse方法與廣播中的處理
**/
registerReceiver(mBroadcastReceiver,newIntentFilter(GpCom.ACTION_RECEIPT_RESPONSE));
/**
*標(biāo)簽?zāi)J较拢勺栽搹V播,在需要打印內(nèi)容的最后加入addQueryPrinterStatus(RESPONSE_MODE mode)
*,在打印完成后會接收到,action為GpCom.ACTION_LABEL_RESPONSE的廣播,特別用于連續(xù)打印,
*可參照該sample中的sendLabelWithResponse方法與廣播中的處理
**/
registerReceiver(mBroadcastReceiver,newIntentFilter(GpCom.ACTION_LABEL_RESPONSE));
}
@Override
protected void initView() {
print.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch(v.getId()) {
caseR.id.print_print:
if(mGpService==null) {
UIUtils.showMessage("服務(wù)正在開啟");
}else{
try{
inttype =mGpService.getPrinterCommandType(1);
if(type == GpCom.ESC_COMMAND) {
mGpService.queryPrinterStatus(1,1000,REQUEST_PRINT_RECEIPT);
}else{
Toast.makeText(this,"Printer is not receipt mode", Toast.LENGTH_SHORT).show();
}
}catch(RemoteException e1) {
e1.printStackTrace();
}
}
break;
}
}
private void sendReceipt() {
EscCommand esc =newEscCommand();
esc.addInitializePrinter();
esc.addPrintAndFeedLines((byte)3);
esc.addSelectJustification(EscCommand.JUSTIFICATION.CENTER);//設(shè)置打印居中
esc.addSelectPrintModes(EscCommand.FONT.FONTA, EscCommand.ENABLE.OFF, EscCommand.ENABLE.ON, EscCommand.ENABLE.ON, EscCommand.ENABLE.OFF);//設(shè)置為倍高倍寬
esc.addText("asdfkldsjgfsdl\n");//打印文字
esc.addPrintAndLineFeed();
/*打印文字 */
esc.addSelectPrintModes(EscCommand.FONT.FONTA, EscCommand.ENABLE.OFF, EscCommand.ENABLE.OFF, EscCommand.ENABLE.OFF, EscCommand.ENABLE.OFF);//取消倍高倍寬
esc.addSelectJustification(EscCommand.JUSTIFICATION.LEFT);//設(shè)置打印左對齊
esc.addText("dfkdsgklfds\n");//打印文字
// esc.addText("Welcome to use SMARNET printer!\n"); //打印文字
// /*打印繁體中文需要打印機(jī)支持繁體字庫 */
// String message = "佳博智匯票據(jù)打印機(jī)\n";
// // esc.addText(message,"BIG5");
// esc.addText(message, "GB2312");
esc.addPrintAndLineFeed();
/*絕對位置具體詳細(xì)信息請查看GP58編程手冊 */
esc.addText("商品名稱");
esc.addSetHorAndVerMotionUnits((byte)7, (byte)0);
esc.addSetAbsolutePrintPosition((short)6);
esc.addText("訂單號");
esc.addSetAbsolutePrintPosition((short)10);
esc.addText("狀態(tài)");
esc.addPrintAndLineFeed();
esc.addText("蘋果");
esc.addSetHorAndVerMotionUnits((byte)7, (byte)0);
esc.addSetAbsolutePrintPosition((short)6);
esc.addText("12345");
esc.addSetAbsolutePrintPosition((short)10);
esc.addText("正常");
esc.addPrintAndLineFeed();
esc.addText("果粒橙300ml");
esc.addSetHorAndVerMotionUnits((byte)7, (byte)0);
esc.addSetAbsolutePrintPosition((short)6);
esc.addText("3545456");
esc.addSetAbsolutePrintPosition((short)10);
esc.addText("正常");
esc.addPrintAndLineFeed();
// /*打印圖片 */
// esc.addText("Print bitmap!\n"); //打印文字
// Bitmap b = BitmapFactory.decodeResource(getResources(), R.drawable.gprinter);
// esc.addRastBitImage(b, 384, 0); //打印圖片
// /*打印一維條碼 */
// esc.addText("Print code128\n"); //打印文字
// esc.addSelectPrintingPositionForHRICharacters(EscCommand.HRI_POSITION.BELOW);//
// //設(shè)置條碼可識別字符位置在條碼下方
// esc.addSetBarcodeHeight((byte) 60); //設(shè)置條碼高度為60點
// esc.addSetBarcodeWidth((byte) 1); //設(shè)置條碼單元寬度為1
// esc.addCODE128(esc.genCodeB("SMARNET")); //打印Code128碼
// esc.addPrintAndLineFeed();
/*
* QRCode命令打印此命令只在支持QRCode命令打印的機(jī)型才能使用。在不支持二維碼指令打印的機(jī)型上,則需要發(fā)送二維條碼圖片
*/
esc.addText("商家二維碼\n");//打印文字
esc.addSelectErrorCorrectionLevelForQRCode((byte)0x31);//設(shè)置糾錯等級
esc.addSelectSizeOfModuleForQRCode((byte)6);//設(shè)置qrcode模塊大小
esc.addStoreQRCodeData("dfgdgs");//設(shè)置qrcode內(nèi)容
esc.addPrintQRCode();//打印QRCode
esc.addPrintAndLineFeed();
/*打印文字 */esc.addSelectJustification(EscCommand.JUSTIFICATION.CENTER);//設(shè)置打印左對齊
esc.addText("Completed!\r\n");//打印結(jié)束
//開錢箱
esc.addGeneratePlus(LabelCommand.FOOT.F5, (byte)255, (byte)255);
esc.addPrintAndFeedLines((byte)8);
Vector<Byte> datas = esc.getCommand();//發(fā)送數(shù)據(jù)
byte[] bytes = GpUtils.ByteTo_byte(datas);
String sss = Base64.encodeToString(bytes, Base64.DEFAULT);
intrs;
try{
rs =mGpService.sendEscCommand(1, sss);
GpCom.ERROR_CODE r = GpCom.ERROR_CODE.values()[rs];
if(r != GpCom.ERROR_CODE.SUCCESS) {
Toast.makeText(getApplicationContext(), GpCom.getErrorText(r), Toast.LENGTH_SHORT).show();
}
}catch(RemoteException e) {
//TODO Auto-generated catch block
e.printStackTrace();
}
}
}

至此大功告成,打印出東西之后感覺好爽

以上所述是小編給大家介紹的Android手機(jī)通過藍(lán)牙連接佳博打印機(jī)的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Android基于socket實現(xiàn)的簡單C/S聊天通信功能

    Android基于socket實現(xiàn)的簡單C/S聊天通信功能

    這篇文章主要介紹了Android基于socket實現(xiàn)的簡單C/S聊天通信功能,結(jié)合實例形式分析了Android使用socket實現(xiàn)客服端與服務(wù)器端數(shù)據(jù)的發(fā)送與接收處理技巧,需要的朋友可以參考下
    2016-10-10
  • cocos2d-2.0-x-2.0.3 交叉編譯到android報錯解決

    cocos2d-2.0-x-2.0.3 交叉編譯到android報錯解決

    我用的是cocos2d-2.0-x-2.0.3 之前弄了一天也沒成功 今天來了下載了最新的ndk8 更新了sdk 又重新是了一遍 居然成功了,不知道是工具的版本問題還是哪一步出錯誤了,在這里詳細(xì)的整理一下,感興趣的朋友可以了解下
    2013-01-01
  • Kotlin fun函數(shù)使用方法

    Kotlin fun函數(shù)使用方法

    函數(shù)是執(zhí)行特定任務(wù)的一組相互關(guān)聯(lián)的代碼塊。函數(shù)用于將程序分解為不同的子模塊。它使代碼可重用,并使程序更易于管理,這篇文章主要介紹了Kotlin fun函數(shù)使用方法
    2022-12-12
  • Android實現(xiàn)簡易計算功能

    Android實現(xiàn)簡易計算功能

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)簡易計算功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • android FM播放時拔出耳機(jī)后FM APP自動close解決方法

    android FM播放時拔出耳機(jī)后FM APP自動close解決方法

    android FM播放時拔出耳機(jī)后FM APP自動close關(guān)閉的情況應(yīng)該怎樣解決呢?下面為大家詳細(xì)介紹下具體修改方法,感興趣的朋友可以參考下
    2013-06-06
  • flutter實現(xiàn)頭部tabTop滾動欄

    flutter實現(xiàn)頭部tabTop滾動欄

    這篇文章主要為大家詳細(xì)介紹了flutter實現(xiàn)頭部tabTop滾動欄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Android編程基于重力傳感器實現(xiàn)橫豎屏放向切換功能

    Android編程基于重力傳感器實現(xiàn)橫豎屏放向切換功能

    這篇文章主要介紹了Android編程基于重力傳感器實現(xiàn)橫豎屏放向切換功能,結(jié)合具體實例形式分析了Android基于重力傳感器實現(xiàn)橫豎屏切換的相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • android ListView結(jié)合xutils3仿微信實現(xiàn)下拉加載更多

    android ListView結(jié)合xutils3仿微信實現(xiàn)下拉加載更多

    本篇文章主要介紹了android ListView結(jié)合xutils3仿微信實現(xiàn)下拉加載更多,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 基于Flutter實現(xiàn)轉(zhuǎn)場動效的示例代碼

    基于Flutter實現(xiàn)轉(zhuǎn)場動效的示例代碼

    動畫經(jīng)常會用于場景切換,比如滑動,縮放,尺寸變化。Flutter?提供了Transition系列的動畫組件,可以讓場景轉(zhuǎn)換動畫變得更加簡單。本文整理了常用的Transition組件的應(yīng)用,需要的可以參考一下
    2022-05-05
  • Android之線程池ThreadPoolExecutor的簡介

    Android之線程池ThreadPoolExecutor的簡介

    今天小編就為大家分享一篇關(guān)于Android之線程池ThreadPoolExecutor的簡介,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03

最新評論