java代码保持不锁屏 java代码保持不锁屏状态

java锁屏,禁用组合键java自身也有键盘事件java代码保持不锁屏的监听 java代码保持不锁屏你可以对所有java代码保持不锁屏的键盘操作都不响应 这样不会影响java代码保持不锁屏你的程序的
三星4412,如何让Android禁止锁屏幕,求解答?方法很简单java代码保持不锁屏: 一:我们只要在程序中用代码实现 。代码如下:[java] view plaincopy //方法一getWindow().setFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON, WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON); setContentView(R.layout.main);//方法二@Overrideprotected void onResume() {super.onResume();pManager = ((PowerManager) getSystemService(POWER_SERVICE));mWakeLock = pManager.newWakeLock(PowerManager.SCREEN_BRIGHT_WAKE_LOCK| PowerManager.ON_AFTER_RELEASE, TAG);mWakeLock.acquire();}@Overrideprotected void onPause() {super.onPause();if(null != mWakeLock){mWakeLock.release();}}//方法三public void unLock(){mContentResolver = getContentResolver();//不建议使用//setLockPatternEnabled(android.provider.Settings.System.LOCK_PATTERN_ENABLED,false);//推荐使用setLockPatternEnabled(android.provider.Settings.Secure.LOCK_PATTERN_ENABLED,false);}private void setLockPatternEnabled(String systemSettingKey, boolean enabled) {//不建议使用//android.provider.Settings.System.putInt(mContentResolver,systemSettingKey, enabled ? 1 : 0);//推荐使用android.provider.Settings.Secure.putInt(mContentResolver, systemSettingKey,enabled ? 1 : 0);}//但注意要加权限AndroidManifest.xml文件中加入//uses-permission android:name="android.permission.WRITE_SETTINGS" ///还要特别注意的是要加入 android:sharedUserId="android.uid.system" , 但有一个问题,//如果加入了sharedUserId后就不能使用eclipse编译了,一定要手动通过 mm -B进行编译,然后把apk install到模拟器或设备中二:禁用系统的锁频功能,这方法不建议使用,只有在设当的环境下适当使用既可 , 我们只要知道这样我们也可以达到这样的功能实现就OK 。我们知道Android系统的锁屏时间存放在Setting数据库中,字段为Settings.System.SCREEN_OFF_TIMEOUT 。我们可以查看SettingsProvider源码,查看如下文件的源码如下: ~/frameworks/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java查看loadSystemSettings()函数的代码如下 [java] view plaincopy private void loadSystemSettings(SQLiteDatabase db) {SQLiteStatement stmt = db.compileStatement("INSERT OR IGNORE INTO system(name,value)"" VALUES(?,?);");Resources r = mContext.getResources();loadBooleanSetting(stmt, Settings.System.DIM_SCREEN,R.bool.def_dim_screen);loadSetting(stmt, Settings.System.STAY_ON_WHILE_PLUGGED_IN,"1".equals(SystemProperties.get("ro.kernel.qemu")) ? 1 : 0);loadIntegerSetting(stmt, Settings.System.SCREEN_OFF_TIMEOUT,R.integer.def_screen_off_timeout);// Set default cdma emergency toneloadSetting(stmt, Settings.System.EMERGENCY_TONE, 0);// Set default cdma call auto retryloadSetting(stmt, Settings.System.CALL_AUTO_RETRY, 0);// Set default cdma DTMF typeloadSetting(stmt, Settings.System.DTMF_TONE_TYPE_WHEN_DIALING, 0);// Set default hearing aidloadSetting(stmt, Settings.System.HEARING_AID, 0);// Set default tty modeloadSetting(stmt, Settings.System.TTY_MODE, 0);loadBooleanSetting(stmt, Settings.System.AIRPLANE_MODE_ON,R.bool.def_airplane_mode_on);loadStringSetting(stmt, Settings.System.AIRPLANE_MODE_RADIOS,R.string.def_airplane_mode_radios);loadStringSetting(stmt, Settings.System.AIRPLANE_MODE_TOGGLEABLE_RADIOS,R.string.airplane_mode_toggleable_radios);loadBooleanSetting(stmt, Settings.System.AUTO_TIME,R.bool.def_auto_time); // Sync time to NITZloadIntegerSetting(stmt, Settings.System.SCREEN_BRIGHTNESS,R.integer.def_screen_brightness);loadBooleanSetting(stmt, Settings.System.SCREEN_BRIGHTNESS_MODE,R.bool.def_screen_brightness_automatic_mode);loadDefaultAnimationSettings(stmt);loadBooleanSetting(stmt, Settings.System.ACCELEROMETER_ROTATION,R.bool.def_accelerometer_rotation);loadDefaultHapticSettings(stmt);stmt.close();}我们通过查看源码便知道,Settings.System.SCREEN_OFF_TIMEOUT没有初始化的话(系统首次启动 , 这个字段肯定是没 有初始化的),系统将会利用资源中的R.integer.def_screen_off_timeout来初始化 。我们为了让系统永不锁屏,只需要把资源 R.integer.def_screen_off_timeout设为-1即可 。查看文件在这里: frameworks/base/packages/SettingsProvider/res/values/defaults.xml 可以找到R.integer.def_screen_off_timeout的定义[xhtml] view plaincopy integer name="def_screen_off_timeout"60000/integer发现默认值为60000ms , 也就是60s 。我们只需要把这个参数改为-1 。然后重新编译SettingsProvider模块,就OK了 。但有时候也会有这样的情况发生,用户进入系统后,修改锁屏时间,为了这样的情况发生我们得在Setting模块中删除对锁屏时间的设置 。这样Android设备就不锁屏了 。我们这里还要处理一种情况 , 就是让系统一启动我们就禁用锁屏的功能,很简单,我们只要把系统锁 屏 功能的的初始默认开关给改以下就可以了,如下找到这个类: frameworks/policies/base/phone/com/android/internal/policy/impl/KeyguardViewMediator.java该文件中有一个变量定义如下: [java] view plaincopy /*** External apps (like the phone app) can tell us to disable the keygaurd.*/private boolean mExternallyEnabled = truemExternallyEnabled是用来管理是否开启屏幕锁的关键 。默认值是打开屏锁,根据注释可以知道java代码保持不锁屏他是希望应用程序来修改这个 值,我们可以把这个值改成false就可以了 。有时候我们不想修改这个初始值 , 那我们看看这个类有没有提供相应的方法来供外部修改这个值的,不出我们所料,看下面这段代码就是的了: [java] view plaincopy /*** Same semantics as {@link WindowManagerPolicy#enableKeyguard}; provide* a way for external stuff to override normal keyguard behavior. For instance* the phone app disables the keyguard when it receives incoming calls.*/public void setKeyguardEnabled(boolean enabled) {synchronized (this) {if (DEBUG) Log.d(TAG, "setKeyguardEnabled("enabled")");mExternallyEnabled = enabled;if (!enabledmShowing) {if (mExitSecureCallback != null) {if (DEBUG) Log.d(TAG, "in process of verifyUnlock request, ignoring");// we're in the process of handling a request to verify the user// can get past the keyguard. ignore extraneous requests to disable / reenablereturn;}// hiding keyguard that is showing, remember to reshow laterif (DEBUG) Log.d(TAG, "remembering to reshow, hiding keyguard, ""disabling status bar expansion");mNeedToReshowWhenReenabled = true;hideLocked();} else if (enabledmNeedToReshowWhenReenabled) {......}}我们可以在我们需要修改这个值的地方来调用这个函数去修改,挺简单的吧 , OK,锁频就讲到这里 , 其实锁屏这块还有挺多的知识点. 要想深入的了解其实挺麻烦的,如果大家对锁频有了个比较深入的了解的话,可以尝试自己开发一个琐屏的程序看看 。
java写的socket tcp连接在小米手机上,app在前台tcp连接正常,app一退到后台或锁屏,tcp过一会儿就断开了最近我在在写一个APP , 用到了socket,在自己电脑上搭建的服务器,具体过程:用eclipse写Java代码 , 创建一个serversocket,用来监听客户端的请求;客户端在发送数据前,首先创建一个Socket , 然后直接请求服务器即可 。
如何使用java程序实现windows锁屏先请编译和运行下面程序:
import java.util.*;
import java.io.*;
public class BadExecJavac2
{
public static void main(String args[])
{
try
{
Runtime rt = Runtime.getRuntime();
Process proc = rt.exec("javac");
int exitVal = proc.waitFor();
System.out.println("Process exitValue: "exitVal);
} catch (Throwable t){
t.printStackTrace();
}
}
}
我们知道javac命令,当不带参数运行javac
程序时 , 它将输出帮助说明,为什么上面程序不产生任何输出并挂起,永不完成呢?java文档上说,由于有些本地平台为标准输入和输出流所提供的缓冲区大小
有限,如果不能及时写入子进程的输入流或者读取子进程的输出流,可能导致子进程阻塞,甚至陷入死锁 。所以,上面的程序应改写为:
import java.util.*;
import java.io.*;
public class MediocreExecJavac
{
public static void main(String args[])
{
try
{
Runtime rt = Runtime.getRuntime();
【java代码保持不锁屏 java代码保持不锁屏状态】Process proc = rt.exec("javac");
InputStream stderr = proc.getErrorStream();
InputStreamReader isr = new InputStreamReader(stderr);
BufferedReader br = new BufferedReader(isr);
String line = null;
System.out.println("");
while ( (line = br.readLine()) != null)
System.out.println(line);
System.out.println("");
关于java代码保持不锁屏和java代码保持不锁屏状态的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读