PhoneGap - 强制横向

Posted

技术标签:

【中文标题】PhoneGap - 强制横向【英文标题】:PhoneGap - Forcing Landscape orientation 【发布时间】:2012-04-05 18:22:41 【问题描述】:

我昨天开始研究 PhoneGap,并在倾斜手机时创建了一个简单的“大理石”滚动。我目前正在 android 上开发,但我希望方向保持为景观美化,而不是在手机旋转时移动。有没有办法做到这一点?

清单:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.phonegap.helloworld"
    android:versionCode="1"
    android:versionName="1.0" >
<supports-screens
    android:largeScreens="true"
    android:normalScreens="true"
    android:smallScreens="true"
    android:resizeable="true"
    android:anyDensity="true"
/>
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECEIVE_SMS" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.BROADCAST_STICKY" />
<uses-sdk android:minSdkVersion="8" />
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".App" 
            android:configChanges="orientation|keyboardHidden"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity 
            android:name="com.phonegap.DroidGap" 
            android:label="@string/app_name" 
            android:screenOrientation="landscape"
            android:configChanges="orientation|keyboardHidden"> 
            <intent-filter></intent-filter> 
        </activity> 
    </application>
</manifest>

代码:

package com.phonegap.helloworld;

import android.os.Bundle;
import org.apache.cordova.*;

public class App extends DroidGap 
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        super.loadUrl("file:///android_asset/www/index.html");
    

【问题讨论】:

在 Apache Cordova 3.0 发布后修改 AndroidManifest.xml 将破坏 Cordova 开发工作流程。改用插件。在此处查看可能的重复响应:***.com/questions/20294090/… 【参考方案1】:

你试过吗?

android:screenOrientation="portrait"

在您声明活动的AndroidManifest.xml 文件中,只需添加上述行。

例如:

<activity
            android:name=".Activity.SplashScreenActivity"
            android:label="@string/app_name"
            android:screenOrientation="portrait">
            <intent-filter>
                <action
                    android:name="android.intent.action.MAIN" />
                <category
                    android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

【讨论】:

我将它添加到错误的活动标签中,所以这是赢家!欢呼 安东的回答是更好的选择【参考方案2】:

对所有设备执行此操作的正确方法是配置 config.xml

<preference name="orientation" value="portrait" />

<preference name="orientation" value="landscape" />

https://build.phonegap.com/docs/config-xml

【讨论】:

Phonegap 似乎对我忽略了这些设置,无论它们的价值如何。 理想情况下,这将在所有 PhoneGap 平台上完美运行。我的理论是 PhoneGap WebView 可能被锁定到某个方向,但它包含的 Activity 根据 AndroidManifest.xml 中的属性旋转。但是,我仍然认为这可以通过 PhoneGap 解决; PhoneGap 可以编辑 AndroidManifest.xml,或者 DroidGap 类可以管理/防止旋转。 @apanosa:这个解决方案是关于 phonegap 构建的。我确认它现在可以在 ios 7.x 和 android 2.x 上使用 phonegap 3.4.0。 这是定义东方的正确方式。谢谢安东【参考方案3】:

很简单,你需要在AndroidManifest.xml文件中添加android:screenOrientation="landscape"

<application android:icon="@drawable/icon" android:label="@string/app_name">
    <activity android:name=".LogUploaderActivity" android:label="Log Uploader" android:screenOrientation="landscape" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

【讨论】:

【参考方案4】:

请在您的活动中尝试此操作。在 onCreate() 内部和 setContentView 之前。

// keeps the screen orientation in Landscape mode
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

【讨论】:

不确定该放在哪里,我之前没有接触过java。 @PhilJackson 在主要活动的 onCreate() 方法中:-)【参考方案5】:

也许值得一提,因为我不知道:

如果您使用在线 phonegap apk 转换器并为您的应用程序启用了水合,则您必须完全重建您的应用程序,而不仅仅是更新它。这也将帮助您处理诸如“方向”或“全屏”之类的偏好!

【讨论】:

以上是关于PhoneGap - 强制横向的主要内容,如果未能解决你的问题,请参考以下文章

Phonegap/cordova IOS横向视频

如何使用 phonegap 构建同时支持纵向和横向启动屏幕?

Phonegap 页面旋转错误,横向显示为纵向

在 phonegap 应用程序中以编程方式设置纵向或横向

jQuery Mobile-Phonegap:Windows 8 横向模式下的页脚对齐问题

带有 Phonegap 的 Android 应用程序在横向旋转时崩溃